SERVICE FOR GENERATION OF CUSTOMIZABLE DISPLAY WIDGETS
A system for presenting dynamically generated images in a computing environment is provided. The system generates visual elements, such as widgets, for example, by combining image data, user-defined data which may include alphanumeric data, and real-time data indicative of current conditions. The widgets may be implemented in a purely server-side application environment which alleviates the need for any installation of client software on the client computing device.
The application is a continuation of U.S. application Ser. No. 11/504,361, filed Aug. 14, 2006, which claims the benefit of U.S. Provisional Patent Appl. No. 60/707,780, filed on Aug. 12, 2005. The disclosures of the aforesaid applications are hereby incorporated by reference.
BACKGROUND OF THE INVENTION1. Field of the Invention
This application relates to graphical user interface elements in computing devices. More specifically, this application relates to a system and method for presenting information in a visually compelling manner to effectively convey the information in a static or dynamic environment.
2. Description of the Related Art
Visual images have long been used to convey ideas and information more effectively than by written words or numerals alone. As techniques have been developed allowing for the relatively inexpensive cost of creating and reproducing images, image content has become more relevant to communication. Images have become more pervasive in our day-to-day lives as a result of techniques developed to reproduce images for mass distribution. Halftone and four-color reproduction processes have allowed the printing press to present images to a wide public. Photographic film and associated projection techniques have formed the basis of the movie industry which presents large scale moving images to hundreds of millions of viewers around the world. Broadcast media such as television and cable present an even larger quantity of images to a growing international public comprising individuals who spend on average several hours each day viewing these images. With the development of inexpensive consumer video cameras and editing equipment many individuals are now creating their own moving images, which are enjoying widespread distribution on broadcast media and the Internet. As society has become more image-dependent, information presented in a text-based or non-graphical manner begins to have diminished impact and effectiveness. Information that might have been otherwise effectively conveyed textually or numerically in the past is often now ignored in a more image-focused society.
Although society has become more image-based, developments in computer technology have also resulted in an increase in the amount of data that is relevant and available in people's lives. Although this increase in available data is intended to provide the benefit of increased knowledge, the sheer volume of data available makes it increasingly difficult to present the data in a visually compelling manner. Information that a few years ago might have otherwise been effectively conveyed with text, numerical characters and limited graphics, might be ignored today without being presented in a more visual appealing way. Therefore, what is needed are systems and methods that allow accurate and timely data to be presented in a visually compelling manner.
SUMMARYThe system, method, and devices of the present invention each have several aspects, no single one of which is solely responsible for its desirable attributes. Without limiting the scope of this invention, several of its features will now be discussed briefly.
In one embodiment, a system for defining a visual element in a display interface is provided. The system may include a data storage system for storing visual element defining data. The visual element defining data may comprise image data having a base image component and other image components. The defining data may also include alphanumeric data representing information to be conveyed in the defined visual elements. The defining data may further include real-time data indicative of current conditions. The system may also include a generation module configured to generate the visual element based on the defining data, and further may include a network interface module configured to receive client requests related to the defined visual element and send the visual element defining data that is responsive to the request.
In this description, reference is made to the drawings wherein like parts are designated with like numerals throughout.
Certain embodiments described herein provide for the display of visual elements for conveying information in a computing device. In one or more embodiments, aspects of the invention may provide a system that allows users to create a customized web page or desktop computing environment. Users are able to access a website and setup a personalized account to use the website. The operator of the website provides the user with various widgets that may be selected by the user and placed in their user interface environment. The widget environment may utilize widget containers which provide a framework for extending specific functionality globally across certain sets of widgets, while enabling each individual widget to address functional processes singularly. The operator of such websites may be referred to as a widget service provider.
In certain embodiments, the system may be based on a web services model. The web services model may be advantageous in that it provides easy and widespread distribution targeting the widely available devices that have web browser capability. A web services model may further provide for the easy incorporation of additional services and plug-ins which may be developed by website members and by third parties. The web services model may also provide for development in other technologies such as AJAX or simple HTML, while still allowing access to most services through system API's.
Some implementations provide for user access to the system via a web interface on a web browser. Some widgets may be programmed as Flash applications or applets that run within an active browser window on the device. Users may be able to sent data to the system via HTTP post commands, while the widget service provider may configure web services that update the user's personalized page and associated widgets in response to user device requests and in response to changing data values.
Although the various embodiments herein are described in the context of a web services model, it will be appreciated that other embodiments may include desktop widgets which are persistent on a user's computing device rather than integrated into a browser window.
The network interface device 14 may also be in communication with network interface software 16. In one or more embodiments, the network interface software 16 may be web browsing software such as Internet Explorer, Safari, or Firefox. The network interface software 16 may form a portion of the graphical user interface 12, and may allow users to easily access the functionality of the software. As used herein, a computing device 10 may refer to any type of device that is capable of being configured to access a network 18 and to communicate over the network utilizing network interface software.
The computing device 10 may communicate over the network 18 with a server 20. The server 20 may be a web/application server that is configured to receive requests from the web browsing software 16 and send responses to the computing device 10 in response to the received requests. The server 20 may include a network interface device 22 which allows the server 20 to communicate over the network 18. The server 20 may further include application server software 24 which is configured to receive and respond to requests made to the server 20 via the network 18. The server 20 may also include data storage 26. The data storage 26 may be used to store data related to the application server by the application server 24. The data storage 26 may be in the form of a database or a database management system. Although the embodiment shown in
In one or more embodiments, the server 20 provides functionality for users to define customized display elements or objects that can be displayed in a graphical user interface 12 without requiring any installation of specialized software on the user's computer 10. The objects defined and displayed preferably include sounds, hypertext, and visual images. The objects may be implemented utilizing server-side application technologies, and they may be further implemented using a lightweight application protocol such as applets developed using Macromedia Flash to ensure speed, compatibility and reliability. In other embodiments, the objects may be built using Java or JavaScript.
These display elements may be referred to as widgets. As used herein, a widget is an interface component with which a computer user interacts in a graphical user interface. In some embodiments, a widget may take the form of a small desktop application that provides easy access to frequently used functions and provides some visual information to the user regarding the data returned by the functions.
The display element container 30 may, in some embodiments, be a widget container 30. The widget container 30 may separate the user interface functionality of the widget 28 and the widget application from the platform on which it runs. The widget container 30 may include a widget image element 32, which may be some visual component of the widget. The widget image element 32 may include a base image component which may be an image with characteristics that remain generally constant each time the widget is displayed. The image element 32 may also include sub-images which may be visual components that are combined with the base image along with real-time data and/or other user-specified alphanumeric data to produce a dynamically generated widget image in a manner that will be discussed in further detail below. Thus, the image element 32 may be generated by both the base image and by the widget application using specified data parameters.
The display element container 30 may also include container controls 34. The container controls 34 may be used to provide a framework within which a plurality of widgets 28 may be provided with a core set of GUI functionality. The widget container controls 34 may be insulated from the application portion of the widget so that the basic characteristics of the widget 28 are not changed. Various container controls 34 may be available. For example, in one embodiment, the controls 34 may include a drag and drop positioning handle which allows the user to move the widget 28 easily around the graphical user interface 12. The controls 34 may further include a transparency slider which may provide the ability to change the granularity of the images displayed on the screen. In some embodiments, the controls 34 may further include a minimize button that hides the widget without closing it. The minimize button may be useful when the user does not want the widget 28 on the GUI 12, but still wishes for the application elements of the widget 28 to continue executing in the background. The controls 34 may further include a close button that allows the user to close the widget 28 completely (as opposed to minimizing), and a scale control, which allows a user to resize the widget 28 within the graphical user interface. The controls 34 may also include a mouse-over feature that displays text when the mouse pointer passes over an area of the widget.
As noted above, the display elements 28 may include base images, and other image components. The other image components may be defined in part by external data received by the server 20 and sent to the computing device 10 over the network 18. The external data may include pre-defined image data, real-time data, and/or alphanumeric data.
In some configurations, the server 20 may communicate with external data sources to obtain the data used to help define widget images. Referring now to
Referring now to
In some embodiments, the widget service provider may operate a “backend” system API is which is developed in JAVA, for stability and flexibility in an object-oriented environment. Requested widget data and services are retrieved from the system via http requests. For example the Flash application for an active widget may make the request: http://domain.tld/action=getWidgetList&user=7504. Data may also be retrieved from third party web based resources by direct http request to the desired resource, for example a third party content widget such as a UPS Package Tracker widget may retrieve relevant data directly from the UPS website. These particular features will be discussed in further detail below. As the system uses a web services model, front-end development in other technologies such as AJAX or simple html can be accommodated while allowing access to existing back-end system services through the API. Some widgets rely fully on the API, and others operate independently from the API, for example third party content widgets.
As noted above, visual elements/widgets 28 may be generated on the system server 20 by utilizing base widget image elements 32 and combining them with other data to create the widget 28.
At block 400, the server 20 receives a request to display an image which is stored in the server 20. The request may be sent from a client computing device 10 wherein the user wishes to define a widget to display within the browser software 16. The image request may include various parameters that allow the server 20 to identify the data relevant to the image request. The server 20 may utilize these parameters at block 402 to retrieve image data, alphanumeric data, real-time data, and other data associated with the user request. As discussed previously, these data sources may be external to the server 20, and may be accessed via the network 18. Next, at block 404, the image data to be displayed in the image element 32 of the widget 28 may then be generated (or regenerated for preexisting widgets) by the server 20 based on the data received by the server 20. The process then moves to block 406, where the generated image data is sent to the client device 10 to be placed in the image element 32 of the widget 28. Next, at block 408, commands may be issued to, or actions may be taken at, the server 20, the peripheral devices, or the user device.
Referring now to
The process described in
In certain embodiments, users may be able to select and configure widgets from a fixed number of predefined color themes. Each theme may specify five different color groups:
Widget text color
Widget background color
Headline text color (title on the frame)
Headline information color (frame of the window containing the widget)
Desktop background color
Users may also utilize drag and drop functionality provided in the system that allows user to change the layout of selected widgets on user's main page. When user performs update or logs out of the service, layout is saved. Small icon for each active widget is located at bottom of page. Left click controls whether widget image is made visible on page. Active widgets are visible at the bottom of the user's web page, and emulate the same behavior as a windows style desktop application with controls to drag and drop, minimize or close widget. Moreover, widgets may be provided with mouseover capabilities on an individualized basis.
Turning now to
The container management element 50 may further be configured to display a thumbnail icon of each of the user's active widgets 28 in a list somewhere within the graphical user interface 12. This list may be used by the user to ascertain which widgets 28 are tied to his widget service account, and to activate or deactivate certain widgets 28 stored in the widget container 30.
The widgets 28 displayed in the graphical user interface 12 of
Also present in
Immediately below the numerical calculation widget 58 is a data dependent widget 60. The data dependent widget 60 may be configured to retrieve data at preset intervals and performs actions when a specified condition or conditions are met. These types of widgets allow a user to specify data parameters that define the condition. When the condition is met, a user-selected action may be taken, or the behavior of the data dependent widget 60 may be modified in accordance with the user's instructions. In the example provided in
Other types of widgets may also be made available as shown provided in the table below:
Referring now to
In some embodiments, widget behavior may be determined by the widget's current steady state or a change in state. Behaviors may include (1) sending an e-mail; (2) requesting an HTTP resource (e.g., HTTP Post command); (3) playing a sound; (4) modifying the visual appearance of the widget such as, for example, flashing an image in an alarm widget, displaying a small icon for a reminder widget, or modifying a background color for a countdown widget. Referring now to
The alarm widget process described in
The alarm widget may be configured to execute selected behavior based on the data received from the data sources 36. In one embodiment, the selected behavior may be an Internet-related behavior 70 such as requesting a web resource, sending an e-mail, placing an IP based phone call, or sending an SMS text message. In response to the received data, certain client behaviors 72 may also be programmed into the data dependent alarm widget 60. For example, the widget 60 may be configured to play a sound notifying the user of a change in state. Alternatively, or in addition, the widget 60 may be configured to modify the widget graphic by causing it to change in its visual appearance such as altering its background color or size or causing it to flash on and off. In still other embodiments, the widget 60 may be configured to modify external device behaviors 74 by sending commands to an external device based on the received data. For example, if the widget is programmed to receive data from a thermostat of an air conditioning unit, the widget may be configured to change state when the temperature exceeds a certain threshold. If the air conditioning unit is Bluetooth enabled, a command to cool the room may be sent from the computing device 10 to the air conditioning device when this occurs.
The first step in the loop is block 1106, where the widget requests current data, such as real-time data from external sources 36 from the system server 20. This request may be an HTTP request, an FTP request, or some other form of request. Proceeding to block 1108, the system them determines, based on the external data, whether the alarm condition has been met. If not, the widget waits for a specified time and returns to block 1106 where it resubmits its request for current data.
If the alarm condition has been met, at block 1112, the specified behavior or behaviors are executed due to the condition match. If the behaviors specify exiting the loop, the system proceeds to block 1114 and the process ends. Otherwise, the system returns to block 1106 and the loop begins anew.
As discussed above, the widget container may contain various types of widgets. Another type of widget that may be utilized within the widget container 30 is a user-defined content widget. As discussed above, a user-defined content widget 56 is used to receive, store, and display user-defined content. Examples of these types of widgets are notes widgets (which may behave like electronic sticky notes), list widgets (which may simply store a list of inputted item), and the like.
Depending upon the type of modification, the process may then proceed to some or all of blocks 1206, 1208, and 1210. At block 1206 the system 20 may add an item to the user-defined content if the user-input did the same. Similarly, blocks 1208 and 1210 edit the existing user-defined content in accordance with the changes made by the user at block 1204. Once the changes have been made and stored on the server 20, the process returns to block 1202 where the updated content is displayed to the user.
As discussed briefly above in relation to
Referring now to
In yet another embodiment, it may be useful to minimize the requests made against the RSS server. For example, if the RSS server is heavily taxed, then server responses may be slow and provide unacceptable performance.
As noted above, a third party content provider widget 62 allows a user to obtain information from a third party provider (i.e., an entity other than the widget service provider). The third party provider may be a publicly accessible data source or it may include a password protected data source.
The second flowchart in
As discussed above, the third party content provider widgets 62 may access third party content in a variety of ways.
It will be understood by those of skill in the art that numerous and various modifications can be made without departing from the spirit of the present invention. Therefore, it should be clearly understood that the forms of the invention are illustrative only and are not intended to limit the scope of the invention.
Claims
1-20. (canceled)
21. A computer process for providing a user-customizable widget display on a web page, the process comprising:
- receiving, over a network, a widget request from a user computing device, the widget request specifying widget parameters selected by a user of the user computing device, the widget parameters including at least a widget type and data source; and
- generating a personalized web page for the user, the personalized web page comprising a widget display generated according to the user-selected widget parameters, the widget display including a widget container that displays data retrieved from the data source, the widget display further including a plurality of container controls that provide functionality for interactively manipulating the widget display on the personalized web page;
- said process implemented by a server system that implements a web service.
22. The process of claim 21, wherein the user-selected data source is a user-selected RSS feed.
23. The process of claim 21, wherein the container controls include a control that provides functionality for dragging and dropping the widget container and associated widget content to a new location on the personalized web page.
24. The process of claim 21, wherein the container controls include a resizing control that provides functionality for resizing the widget display.
25. The process of claim 21, wherein the container controls include a minimize control that provides functionality for minimizing the widget container on the personalized page.
26. The process of claim 21, wherein the widget request additionally specifies a user-selected base image, and wherein generating the personalized web page comprises incorporating the base image into the widget display.
27. The process of claim 21, wherein the user-selected widget parameters specify a condition to be checked by application code associated with widget display, and specify an action to be taken when the condition is met.
28. The process of claim 21, wherein the user-selected widget parameters specify visual characteristics of the widget display.
29. The process of claim 21, wherein the data source comprises a heart rate sensor, and the widget display is configured to display a heart rate sensed by the heart rate sensor.
30. The process of claim 21, wherein the data source comprises a biometric sensor, and the widget display is configured to display biometric data sensed by the biometric sensor.
31. The process of claim 21, further comprising, automatically updating the widget display of the personalized web page in response to changes in data values associated with the data source.
32. The process of claim 21, wherein the widget display is controlled by an applet that runs within a browser on the user computing device.
33. The process of claim 31, wherein the applet sends data requests to the web service via the browser, and updates the widget display based on data received from the web service.
34. The process of claim 31, wherein the applet implements a data dependent widget that (1) monitors data for a condition, and (2) performs an action when the condition is met.
35. The process of claim 31, wherein the applet is configured to periodically retrieve information from an external data source other the server system and to update the widget display with the retrieved information.
36. The process of claim 21, wherein the data source is external to the server system, and the process further comprises, by the server system, retrieving data from the external data source.
37. The process of claim 21, wherein the data source is a household appliance.
38. The process of claim 21, wherein the data source is a protected data source for which the user has log-in credentials, and the process further comprises automatically providing the log-in credentials of the user to the data source.
39. The process of claim 21, wherein generating the personalized web page comprises generating a plurality of widget displays, each of which comprises a respective widget container in which widget content is displayed.
40. The process of claim 21, wherein the widget request specifies at least one of the following types of data to be included in the widget display: image data, user-defined data, and real-time data.
41. The process of claim 21, wherein the widget display is independent of an operating system of the user computing device.
42. The process of claim 21, wherein the widget display provides interactive widget functionality without installation of a widget application on the user computing device.
Type: Application
Filed: Sep 11, 2014
Publication Date: Apr 2, 2015
Inventor: Barry Fellman (Miami, FL)
Application Number: 14/484,044
International Classification: G06F 3/0484 (20060101); G06F 3/0481 (20060101);