WO2009063441A2 - A system and method for managing widges - Google Patents

A system and method for managing widges Download PDF

Info

Publication number
WO2009063441A2
WO2009063441A2 PCT/IB2008/055642 IB2008055642W WO2009063441A2 WO 2009063441 A2 WO2009063441 A2 WO 2009063441A2 IB 2008055642 W IB2008055642 W IB 2008055642W WO 2009063441 A2 WO2009063441 A2 WO 2009063441A2
Authority
WO
WIPO (PCT)
Prior art keywords
widgets
widget
contextual data
values
repository
Prior art date
Application number
PCT/IB2008/055642
Other languages
French (fr)
Other versions
WO2009063441A3 (en
Inventor
Keith Waters
Keith Rosenblatt
Original Assignee
France Telecom
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by France Telecom filed Critical France Telecom
Priority to EP08849954A priority Critical patent/EP2223207A2/en
Priority to US12/743,228 priority patent/US20100257196A1/en
Publication of WO2009063441A2 publication Critical patent/WO2009063441A2/en
Publication of WO2009063441A3 publication Critical patent/WO2009063441A3/en

Links

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F9/00Arrangements for program control, e.g. control units
    • G06F9/06Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
    • G06F9/44Arrangements for executing specific programs
    • G06F9/451Execution arrangements for user interfaces
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F16/00Information retrieval; Database structures therefor; File system structures therefor
    • G06F16/20Information retrieval; Database structures therefor; File system structures therefor of structured data, e.g. relational data
    • G06F16/24Querying
    • G06F16/248Presentation of query results
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F3/00Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements
    • G06F3/01Input arrangements or combined input and output arrangements for interaction between user and computer
    • G06F3/048Interaction techniques based on graphical user interfaces [GUI]
    • G06F3/0481Interaction techniques based on graphical user interfaces [GUI] based on specific properties of the displayed interaction object or a metaphor-based environment, e.g. interaction with desktop elements like windows or icons, or assisted by a cursor's changing behaviour or appearance

Definitions

  • the present invention generally relates to graphical user interfaces (GUD and more specifically to the management of user interface elements known as widgets.
  • GUI graphical user interface
  • desktop -of a device can sort the related information displayed through graphical objects, such as windows, menus, taskbars, and the likes. These objects can be customized to facilitate the user interaction with the information, but the experience can prove overwhelming as more graphical objects may overload the GUI
  • Widgets have been introduced to overcome this desktop limitation.
  • Widgets can be defined as light-weight sing Ie -purpose applications that can operate on the user's GUI Widgets may be also seen as scaled-down applications providing only key information rather than fully functional services typically presented on the desktop.
  • widgets may channel information to the user, and allow said user to perform a variety of tasks, including for example communicating with a remote serverto provide information to the user (Le. a widget that needs a synchronization with a data source, like e.g., weather report, list of mails, latest value forhis/her stockportfolio, and the likes), providing commonly needed functionality (e.g., a calculator), or acting as an information repository (e.g., a notebook).
  • Other examples of widgets services are headline news, dictionary, mapping, sticky notes and language translation.
  • widgets While most widgets are connected to on-line web services, such as weather service s, they can also operate off-line, forexample a clock, a game or a local address book. Numerous widgets exist today for desktops and an ever increasing number of them are being generated by simple authoring tools for users.
  • widgets have been developed fora desktop experience, where multiple widgets can be managed. Widgets are now available in lightweight devices such as mobile equipments or devices (e.g. mobile phones), PDAs and the likes. The widgets are then called mobile widgets and correspond generally to mini-applications that deliver customized visual information to a mobile display.
  • Example widgets services are: headline news, current weather, dictionary, mapping, sticky notes and language translation, similarly to the widgets available on desktop computers. As mobile devices may track their position (through GPS for example), location based services (LBS) may be accessible through location based widgets.
  • LBS location based services
  • Widgets a re quintessentia Uy suited to small displays where use r inte ra c tio ns are hard to perform.
  • Mobile phones are suitable platforms for these mini- applications because the content presentation is condensed to only essential visual components.
  • FlG. 5 illustrates the GUI 810 of a mobile device 800 with a possible active widgets layout.
  • a plurality of widgets 820 is actively displaying thanks to a browser 815 information in small regions of the GUI 810.
  • a browser 815 information in small regions of the GUI 810.
  • the widgets 820 may be selected using the navigation button 830 and/or the keypad 835 to zoom in the selected widget. Such a selection could allow for a farmore detailed set of information from the selected widget. Widgets in general have limited customization, whether they are used for mobile equipment or not. They can generally be configured, Le. modified through configuration settings, also called here after preferences. A stock tracker widget can be configured to display certain stocks. The selection of a postal code may be used to configure a weather widget to report weather from a given area or city.
  • a user may change the widget preferences over time, for instance when he/she arrives in a different location, needs a traffic report for a specific itine ra ry, o r whe n his/ he r sto c k p o rtfo Ho has changed.
  • a widget can also be deactivated if the userisno Io ng e r inte re ste d in monitoring a given piece of information.
  • widget management engine and method is described in Apple US 11/499,887.
  • a set of widgets can be managed on a desktop through use r inp ut o f c o nfig ura tio n information and synchronized with a data source.
  • the widgets sets of two distinct devices may be synchronized with one another.
  • Some widgets, e.g. a news, weather or traffic widgets, may need a periodic synchronization with a data source to update the displayed information. For example, a news widget needs an update to display the latest news, a mail box widget needs to synchronize with a mail server to give an up to date status ofa user's mailbox.
  • content updates are limited by essence because the content updates are linked to what the data source may provide. Furthermore, the update may be periodic, e ithe r c o ntro lie d by the end device itself of the widget module. They may also be triggered by the data source whenever an update is available.
  • the proposed widget platform is designed to allow users to select widgets, typically from an online source and subsequently configured the selected widgets once for display.
  • a widget engine in this context is responsible for the execution and display of the widgets. When the engine is operational, no dynamic widget control is performed. Each widget operates independently with a data source such as a web service. Only through manual intervention by the userare widgets removed from the display. This is achieved through a graphical user interface with e xp Hc it b utto ns and graphical objects that allow widgets to be incorporated in the final display or not. Likewise manual intervention through a graphical user interface is re quired for each widget to modify a widget's preferences.
  • Content adaptation for mo bile handsets deals with mechanisms that determine the devices physical characteristics, in particular screen width, height and bit depth, as well other resources, to determine how to shape the content to fit the device.
  • Mobile content adaptation can occur either on the device, or alternatively in the network prior to being accessed by the device.
  • Tb date it is not possible to activate, or deactivate, a set of widgets displayed on a GUIbased upon preferences. Furthermore, it is neither possible to adapta widget presentation based onthe contextual information of the device they are displayed on. Content adaptation is still constrained to the device physical characteristics. It would be also highly desirable if the managementof the widgets could be performed without user intervention.
  • the present method proposes a method formanaging a set of widgets displayed on the graphical user interface (GUI) of a device, said method comprising the acts of:
  • an automatic management and control of a plurality of widgets is permitted on a device though the definition of context b a se d se Ie c tio n me c ha nisms.
  • This me tho d is p a rtic ula rly re Ie va nt to sma 11 sc re e n mobile deviceswitha p lura lity o f wid g e ts.
  • the controlofthe widgets is achieved through the use of predefined rules - which correspond to the widget configurations - that determine individual widget behavior as functions of the device's contextual data.
  • the user's experience with widgets is improved through the combination of multiple widget selection and individual widget preferences on various GUIs, such as, but not limited to, small sere en devices.
  • GUID graphical user interface
  • the present invention also relates to a computer program comprising instructions that cause a computerto implement the present method, as well as a GUIc o up led to the present processor.
  • FlG.1 shows an exemplary embodiment of the system according to the inve ntio n
  • FlG.2 shows a flow chart illustrating how the state of a set of widgets may shift a c cording to an exemplary embodiment of the present method
  • FlG.3 shows a detailed flow chart illustrating how the preference module selects configuration settings for the set of widgets according to the exemplary embodiment of the present method
  • FIG. 4 shows an exemplary illustration of the widgets content shift according to an additional embodiment of the present method
  • FIG.5 shows a mobile handset with a display illustrating a browser with active widget icons
  • FIG.6 shows a detail of the mobile display with a possible three by three widget icon layout, and;
  • FIG.7 shows a time line illustrating the potential widgets displayed within a Weekday AM, Weekday PM cycle combined with weekend cycle.
  • the system and method described therein allows a unique personalized experience forthe user.
  • the system willbe described hereafterin its application to a widget server with which a mobile device (such as a cellular phone) interacts.
  • a mobile device such as a cellular phone
  • client device such as a personal computer, a PDA, a phone, or the likes.
  • the different modules may also be hosted by separate servers and accessible over a network.
  • a widget generally refers to the application itself, while a widget icon is its representation on the GUI
  • wid g e t will also be used to refer to the widget icon.
  • drawings are included for illustrative purposes and do not represent the scope of the present system. Unless specified otherwise, the exemplary embodiment will be described hereafter in the context of a mobile device interacting with a distant widget server.
  • FlG.1 shows an exemplary embodiment of the system according to the invention.
  • a electronic or telecommunication device 100 comprising a user interface, like a GUI, is used by an end-user to display a set of widgets on said inte rfa c e .
  • the device is a mobile equipment or handset.
  • Such a light weight (Le. with limited C e ntra 1 Pro c e ssing Unit) mobile device may be equipped with a web browser, Le. a software application that enables a user of the device to display and interact with text, images, videos, music and other information comprised on a webpage built by a website the device may connect to.
  • a website is generally hosted by a server accessible through a network such as e.g. the World Wide Web or through a local are a network (LAN).
  • LAN network
  • the system according to the exemplary embodiment of FlG. 1 further comprises a widget module or server 110 responsible for managing the set of widgets displayed on the GUI of the device.
  • Widget module 110 is also responsible for providing the widget content to device 100.
  • Widget server 110 maybe seen as a web server responsible for serving the widget framework and widget update data to the device 100.
  • Device 100 is adapted to collect and forward to the widget module 110 c o ntextual information about said device.
  • Bv contextual information one may understand any parameter describing o r c ha ra c te rizing the present state of the device. This may include its location (when the device can track its position), time, temperature, ... This could include forexample, but not limited to, the state of its memory, the type of networkit is connected to, the state o f its b a tte ry, ...
  • each widget corresponds configuration settings or preferences, which allow the control and adaptation of the widget, and the information it will display.
  • the configuration settings may cause the widget to be active or not (Le. displayed on the GUIornot), to display different types of content, ...
  • the configuration settings for each widget available to the device 100 are context-based configurations, Le. they are defined as functions of the possible values of the device 100 contextual information or data. These settings are stored in a preference repository 125, e.g. a relationaldatabase.
  • the active orinactive state of a widget may be defined as a func tio n o f the c o ntextual info rma tio n.
  • a widget maybe rendered active orinactive based on the device contextual information.
  • the contextual information is the time
  • the widget may be active during this time interval of the day, and inactive during this o the r time . Therefore, the active /inactive state of a widget may be defined in repository 125 as a function of the time, Io c ation, or any c ontextual information device 100 may monitor.
  • the content displayed may be configured to vary during the day, displaying general news in the morning for example, and sports news in the evening.
  • widget server 110 once it has collected the contextual information from the device 100, is arranged to query repository 125 with sa id c o nte xtua 1 info rma tio n.
  • widget server 110 may build a webpage with the widgets operating according to the updated widget settings matching the present conte xtua linfo rma tion of the device.
  • FlG. 7 illustrates an example of a GUI of a device 100 performing an exemplary embodiment of the method according to the invention.
  • a series or set of widgets have been selected by a user. These widgets are namely: - a weatherwidget,
  • a news widget that may display headline news, sports news, or business news
  • - a game widget are displayed on .
  • a set of widgets may be seen as the widgets of interest to the end-user. He/she may at any time update the set of widgets by removing or adding new widgets, and defining configurations settings for the added widgets.
  • the p re se nt syste m and method allow fora display of only the most relevant widgets to the users, taking into account his/her varying interest that are expressed as functions of the device contextual information.
  • the present system allows for an update of the displayed widget content that goes beyond the simple synchronization with a data source.
  • the configuration settings of these widgets may be defined for example as a function of the time and the location of the mobile handset in repository 125.
  • the configuration settings of the news widget may be defined so that the news widget is configured to display general news in the morning of a weekday, business news in the afternoon of a weekday, and sports news on a weekend from the same data source.
  • the configuration settings of the news widget allows to synchronize this widget with difference sources depending in this example on the time of the day and of the week. In the present system, the synchronization with a data source is thus based on the contextual information of the end device.
  • the weather widget preferences are defined so that this widget is configured to be active and synchronize the weather information fora different region depending on the day of the week.
  • a user traveling every weekend to his/her country house may want to have his/her city weather displayed on weekdays, and his/her country house weather starting on Friday to prepare for his/her weekend.
  • the traffic widget may be configured to display only on weekdays morning the road traffic when the user's commutes to work or whenthe usergoesto his c o untry ho me onweekends.
  • the widget module 110 receives the contextual information from device 100, here in this example location and time, it collects from repository 125 the configuration se tting s fo r the set of widgets here above, and configure the widgets accordingly.
  • the widget news displays headline news on weekdays mornings, business news on weekdays evenings and sports news in the weekends.
  • the weather widget active on weekdays, becomes inactive on weekends.
  • widget module 110 may query directly preference repository 125 with the device contextual information (dotted line in FIG. 1). Widget module 110 is then arranged both to retrieve the right preferences from repository 125 and manage and display the set of widgets using said preferences.
  • widget module 110 may query indirectly preference repository 125, the retrieval of the right preferences being handled by a separate module 120, or preference module (as seen in straight lines in FlG.1).
  • Preference module 120 may be a preference server, Le. a web service responsible for providing to widget server 110 the configuration settings matching the device contextual information. Widget server 110 and preference server 120 may be in this example two separate servers interacting over a ne two rk.
  • a user may interact with the preference module 120, which is also responsible forproviding a mechanism through which users can maintain and/or update context-based configuration setting fora selected set of widgets.
  • a preference editor 127 may be used by a user to interact with preference module 120 and modify the configuration settings.
  • the preference editor may be hosted by device 100 oravailable on the preference module 120.
  • a user may access with his/her device 100 the preference module 120, and edit the set of widgets preferences using preference editor 127. He/she may set the weather widget to be active only on weekday mornings, or define the news widget content depending on the time of the day and the week.
  • the preference module may also be accessed from a device other than device 100 used to display the set of widgets.
  • a desktop computer may be for instance used to access the preference module 120 to edit and modify the widget preferences.
  • FIG. 1 corresponds to web based embodiment of the present system.
  • the widget and preference modules may be part of the same module.
  • the widget module maybe a client to the device 100, while the preference module 120 is a distant server.
  • the preference module may be a client to the device 100 while the widget module 110 is a distant server.
  • the maintenance and update of the configuration settings and the retrieval of the right configuration settings, two functions handled by preference module 120 in the illustration in straight lines in FlG. 1 may also be handled by separate modules. Other combinations of the various functions illustrated here above are also within the scope of the present system.
  • Device 100 may also be any web browser-based platform such as a desktop computer or an independent unit hosting most if not all the different modules of the present system.
  • the ace ess to the network may be wireless or not, device 100 being equipped with the right communication interfaces according to ace ess the network.
  • the p re se nt syste m and method allow fora context shifting of the widget set displayed on the device 100, Le. a shifting based on the contextual data of the device.
  • the shifting may be a shift between the active and inactive state of a widget, here after referred to as a state shift, or a shift in the content displayed on the GUI, here after referred to as a content shift.
  • An embodiment of the present method is illustrated in FlG.2 for the state or content shift.
  • the method is illustrated with the preference module and the widget module as separate modules.
  • Device 100 is assumed to display a series or set of widgets as illustrated in the example of in FlG.6. In this example only 3 widgets are active, Le. actively displayed.
  • the exemplary GUI 610 has 9 possible spots to display widgets Wl to W9, with 6 empty through browser 620. Selecting the widget will allow the whole widget to be displayed on the mobile display, for an enhanced and details viewing of the widget information.
  • the end user is also assumed to have selected a set of widgets for his/her device, and define the context based configuration se tting s fo r the selected widgets through the preference editor mentioned earlier on.
  • the end device collects contextual information or data about its present state. This may include location, time, ... as mentioned before. Act 200 may be performed on a regular basis, or whenever one of the monitored contextual parameter varies beyond a given range. The sampling of the different parameters may also vary from one parameter to the other, depending e.g. on its nature. Device 100 then forwards the contextual information to the widget module 110. The forwarded data may be limited to e.g. the parameters that triggered the sampling, the parameters the value of which varied from the previous sampling or all parameters.
  • the widget module in order to update the widget page, queries the preference module 120 with the received contextual information, to retrieve updated preferences for the currently displayed set of widgets.
  • the preference server retrieves the configuration settings for the set of widgets that apply (Le. correspond) to the received contextual information. An update of the set of widgets preferences is thus achieved.
  • preference module 120 may browse repository 125 by widget, orby contextual parameter, orany suitable entry.
  • preference module evaluates end device context against the context based configuration settings, which may be seen as a set of defined rules.
  • the identified preferences are forwarded to the widgetmodule in a further act230, so thatthe widgetmodule may update the set of widgets accordingly , e.g. activating or deactivating a numberof widgets (state shift) and/or changing the rendered information (content shift).
  • preference module returns to the widget module a context-selected set of response data.
  • This returned data includes the widgets themselves (Le. the active ones), as well as the underlying information the widgets use fo r g e ne ra ting the display presented to the end-user.
  • an updated widget page is built using the identified preferences.
  • widget module 110 sends the updated widget page for a further display on the end device.
  • the widget themselves Le. the widget code is returned.
  • the widget code willbe transferred only for a widget which becomes active in the updated widget page. For already running widgets, as only the configuration may change, the data transfer may be limited to the new set of preferences, the update being performed on the client side (end device) or on the widget module.
  • the configuration settings for each widget are stored as func tio ns o f the possible values of the device contextual information.
  • One possible way of storing the settings as functions of the contextual data may be to first define intervals -orranges-ofvaluesfo reach parameter characterizing the contextual information of the device. The different intervals are not necessarily contiguous as illustrated here after.
  • Table 1 An example implementation of various time ranges foruse in time-based preferences is shown here below in Table 1:
  • Table 1 An example time range set
  • n/x-y is defined as: n day of a week(0 to 6) x and y times of the day in 0000 format (e.g.1800 stands for 18h00) x-y interval of a time in a day
  • the configuration settings may be expressed according to each parameter defined intervals.
  • the preferences may be organized by widgets and each parameter interval.
  • each configuration setting of a widget may be divided into preference sets, each preference set listing the widget configuration data valid forthe para meter interval attached to said preference set.
  • the information may be sorted out in repository 125 mainly by the parameter intervals, Le. for each preference subset, the configuration data for all the widgets is defined.
  • Other organization of the c o nfig ura tio n se tting s sto re d in repository 125 are readily available to the man skilled in the art.
  • configuration settings correspond to the traffic , stock and weather widgets that canbe seenin FlG.6 in an exemplary illustration of a mobile display.
  • Their configuration is to vary depending on the moment of the week, namely on weekdays in the morning (weekday AM), weekdays in the afternoon (weekday PM) and weekends, these intervals corresponding to the definition illustrated in Table 1.
  • Four preference subsets are available, corresponding to these three intervals and one default subset.
  • Each subset comprises the widget name, class (here corresponding to a Javascript class), and path to retrieve the widget itself.
  • the configuration data is also provided for each widget, e.g.
  • the weather widget it may be different weather locations to display depending on the time interval, for the traffic, it may be a different itinerary to display, or simply the traffic in the vicinity of the end device actual location, and for the stock widget a list o f sto c ks to monitor.
  • nine positions are available on the mobile display in FlG.6, nine entries are provided for the widget names, classes and paths, "" c orresponding to an empty orunused position.
  • the configuration is set so that the weather, stock and traffic widgets are on display during the weekdays, AM and PM, the display changing to the weatherand sports widgets during the weekend (Le. only two widget icons used).
  • preference module may browse repository 125 by widget first for all the widgets comprises in the set of widgets, and then by parameter intervals. F the information is organized mainly by the parameter intervals, the need to browse widget after widget is no longer
  • FlG. 3 shows an exemplary illustration of act 220 for the time parameter.
  • the widget configuration settings may be defined in the preference re p o sito ry fo r each time range listed here above.
  • preference module selects a first p re fe re nc e subset corresponding to a first time intervaL h a further
  • preference module checks if the selected preference subset apply to the current time of the end device, Le. if the current time is comprised in the time interval of the selected sub se t. F so , the selected preference subset is retained in a furtheract 320 as the subsequent configuration of the set of widgets. Fnot, in a further act 330, the preference module ve rifie s if mo re subsetsare available, if so,
  • preference module 120 may repeat acts 300 to 360 for each widget.
  • the widget module may even update the widget display on a widget after widget basis.
  • preference module performs these acts only once if each preference subset comprises configuration data forthe whole set of widgets.
  • FlG. 4 shows an exemplary illustration of the widgets content shift, once the updated configuration settings have been retrieved by the preference server in a preliminary act 400.
  • widget module checks among the active widgets the one that will require a content update.
  • the updated content is synchronized with the relevant data sources, e.g. web site s for news widgets. With the updated configurations settings and content, widget module may proceed with building the update widget page in a subsequent act 430, and send this page fora further upload by the end device for display in act 440.
  • Tb date mobile web content is typically modified to render web pages onto small screens.
  • Some implementations repurpose content by, for example, eliminating tables and scaling images. These techniques are commonly known as small screen rendering (SSR).
  • SSR small screen rendering
  • Such content adaptation can occur in the network, or Io c ally on the device to minimize bandwidth usage.
  • a HTTP request header is one mechanism by which device characteristics can be determined.
  • HTTP headers are name /value pairs that appearin both request and response messages. The name of the header is separated from the value by a single colon, for example: User- Agent: MoziUa/4.0 (compatible; MSIE 6.0; Windows NT 5.1) Provides a header: User-Agent whose value is Moz ⁇ la/4.0 (compatible; MSIE 6.0; Windows NT 5.1). The purpose of this particular header is to supply the web server with information about the type of browser making the request.
  • a c o mp Ie te d e f ⁇ nitio n o f this a nd o the r c o mmo nly e nc o unte re d HTTP headers can be found in the World Wide Web consortium (W3C) HTTP 1.1 specification. Such techniques are widely used to adapt content.
  • the present system and method extend the content adaptation by introducing a new method for a dap ting content on a device.
  • the state shift obviates the need to scroll though lists of widgets because the time based preferences (or other parameter based preferences) allow pre- selection of widgets to take place. Even a small number of mobile widgets can take up most of the available screen real-estate resulting in a poor user experience that makes it hard to identify the desired widget.
  • State shift automatically determines what widget to display from a plurality of widgets based on a defined set of rules identifying whetherto display widgets to the user.
  • the present system allows the c ontrol of when and forhow long a widget is displayed as well as the control of what content should be presented.
  • a traffic widget for a journey home can be displayed ten minutes before leaving the office, while during the day it can be suppressed allowing other widgets to be displayed.
  • FIG.6 the content shift provides a unique mechanism for the display of a single widget.
  • widgets are able to use contextual information, including but not limited to current time and location of the display device, to tailor displayed content. This capability results in the presentation of information that is relevant to the user at all times.
  • Context aware content display can be accomplished through the use of context-based widget preferences. For example, a news feed generated from a RSS widget could display current world news in the morning, stock market reports at noon and finally a sport feed at the end of the day.
  • the present system allows context aware widget display without modifying the core code of the widget. Instead, the widget module controls when and how to display widgets by evaluating end device context against a set of defined rules on a preference module and returning to the widget display device a context-selected set of response data.
  • This returned data may include the widgets themselves, aswellasthe underlying information the widgets use for generating the display presented to the end-user. As seen before, forthe widgets which are already activated in the GUI, the returned data may only include the updated preferences.
  • the present system is an additional layer of widget management controL
  • the monitored contextual information comprises the device time
  • various granularity may be defined. As time elapses through the week and day, new applications will appear, some will change their appearance, while others are suppressed from view.
  • the automated control of a mobile device graphical use r inte rfa c e can dramatically improve the experience on small devices by presenting only those widgets though a userpreference configuration.
  • a web standards-based widget approach can be contrasted to applications that run on devices that are compiled for a specific target architectures, for example a windows DLL (dynamic a Uy linked library) or a Java application.
  • Other embodiments may be available within the scope of the present system.
  • AHmodules, and their re Ia ted functions may be stored in a single end device, like a mobile phone or a computer. The selection of the widgets of interest to a user, as well as the type of editor he/she may use to configure the context based p re fere nee sis beyond the scope of the present system.
  • the present invention may be implemented through a processor hosted by the telecommunication device 100, this processor being configured to manage a set of widgets displayed on the graphical user interface (GUD of said device 100, said processor comprising:
  • An exemplary embodiment of the telecommunication device 100 may comprise indeed a processor operationally coupled to a memory, a display or GUI, a userinput device and one ormore interface devices.
  • the memory may be any type of device for storing programming application data, such as to support data analysis, as well as other data, such as performance data, end user subscription data, or else.
  • the programming application data and other data are received by the processor for configuring the processor to perform operation acts in accordance with the present method.
  • the operation acts may include controlling the GUI to display the set of widgets, or querying with the device contextual data a repository of widget configurations for the set of widgets.
  • the user input may include a keyboard, mouse, trackball, or other device, such as a touch sensitive display, or the likes.
  • the user input device is operable for interacting with the processor including interaction within the memory of the device, and/orotherelements of the present system.
  • the memory may be one single memory storing the application program to perform the acts of the present method the repository of widget configurations when stored on the device itself.
  • the re p o sito ry fo r sto ring the widget configurations may be a distinct database operatively coupled to the processor, as illustrated in the exemplary embodiment of FlG.1 with preference repository 125.
  • the term "memory" should be construed broadly enough to encompass any information able to be read from or written to an address in the addressable space accessible by a processor. With this definition, information on a network is still within the memory as, for instance, the processormay retrieve the information from the networkforoperation in accordance with the present system.
  • processor may forinstance comprise severalparts orportions, such as a portion configured to receive contextual data from the device, and a portion for querying with the received contextual data a repository of widget configurations for the set of widgets. These portions may themselves be further divided in subparts.
  • the processor, memory, GUI, user input device, and/ or interface device may all or partly be a portion of a c o mp ute r syste m or other device, such as a server.
  • the present method is particularly suited to be carried out by a computer software program, such program containing modules corresponding to one or more of the individual steps or acts described and/or envisioned by the present system.
  • Such program may of course be embodied in a computer-readable medium, such as an integrated chip, a peripheral device or memory, such as the memory and/or other memory coupled to the processor.
  • a computer-readable medium such as an integrated chip, a peripheral device or memory, such as the memory and/or other memory coupled to the processor.

Abstract

The invention relates to method for managing a set o f widgets displayed on the graphical user interface (GUI) of a device, said method comprising the acts of receiving contextual data from the device, querying with the received contextual data a repository of widget configurations for the set of widgets, said widgets configurations being described in said repository as functions of the possible contextual data values, displaying the set of widgets using the configuration that match the received contextual data.

Description

A SYSIEM AND MEIHOD R)RMANAGlNG WIDGETS
HELD OFTHE FΪΦSENTSYSIEM: The present invention generally relates to graphical user interfaces (GUD and more specifically to the management of user interface elements known as widgets.
BACKGHOUND OFTHE FΪΦSENTSYSIEM: Tb day, there is an explosion of digital content available over the internet.
With this explosion comes the need to channel and filter the ever increasing content load to avoid an overflow of information, whether the content is pushed orpulled to the users' end devices, such computers, mobile equipments like cell phones, personal digital assistants (PDA) and the likes. Users generally access the content through the graphical user interface
(GUI) - or desktop -of a device and can sort the related information displayed through graphical objects, such as windows, menus, taskbars, and the likes. These objects can be customized to facilitate the user interaction with the information, but the experience can prove overwhelming as more graphical objects may overload the GUI
Widgets have been introduced to overcome this desktop limitation. Widgets can be defined as light-weight sing Ie -purpose applications that can operate on the user's GUI Widgets may be also seen as scaled-down applications providing only key information rather than fully functional services typically presented on the desktop. Generally, widgets may channel information to the user, and allow said user to perform a variety of tasks, including for example communicating with a remote serverto provide information to the user (Le. a widget that needs a synchronization with a data source, like e.g., weather report, list of mails, latest value forhis/her stockportfolio, and the likes), providing commonly needed functionality (e.g., a calculator), or acting as an information repository (e.g., a notebook). Other examples of widgets services are headline news, dictionary, mapping, sticky notes and language translation.
While most widgets are connected to on-line web services, such as weather service s, they can also operate off-line, forexample a clock, a game or a local address book. Numerous widgets exist today for desktops and an ever increasing number of them are being generated by simple authoring tools for users.
To date widgets have been developed fora desktop experience, where multiple widgets can be managed. Widgets are now available in lightweight devices such as mobile equipments or devices (e.g. mobile phones), PDAs and the likes. The widgets are then called mobile widgets and correspond generally to mini-applications that deliver customized visual information to a mobile display. Example widgets services are: headline news, current weather, dictionary, mapping, sticky notes and language translation, similarly to the widgets available on desktop computers. As mobile devices may track their position (through GPS for example), location based services (LBS) may be accessible through location based widgets.
Widgets a re quintessentia Uy suited to small displays where use r inte ra c tio ns are hard to perform. Mobile phones are suitable platforms for these mini- applications because the content presentation is condensed to only essential visual components. While mobile widgets on mobile devices are effective, the mechanisms to manage, control and interact with widgets remains problematic. This is due to impoverished interaction facilities on mobile devices. FlG. 5 illustrates the GUI 810 of a mobile device 800 with a possible active widgets layout. A plurality of widgets 820 is actively displaying thanks to a browser 815 information in small regions of the GUI 810. Forexample the changing weather conditions, current stock values, traffic delays, a calculator or the number of pending emails. The widgets 820 may be selected using the navigation button 830 and/or the keypad 835 to zoom in the selected widget. Such a selection could allow fora farmore detailed set of information from the selected widget. Widgets in general have limited customization, whether they are used for mobile equipment or not. They can generally be configured, Le. modified through configuration settings, also called here after preferences. A stock tracker widget can be configured to display certain stocks. The selection of a postal code may be used to configure a weather widget to report weather from a given area or city. A user may change the widget preferences over time, for instance when he/she arrives in a different location, needs a traffic report for a specific itine ra ry, o r whe n his/ he r sto c k p o rtfo Ho has changed. A widget can also be deactivated if the userisno Io ng e r inte re ste d in monitoring a given piece of information. Some customization of a widget can be done while the widget is running, e.g., by directly interacting with a mouse or keyboard of a desktop or laptop computerora keypad ofa light weight device.
An example of widget management engine and method is described in Apple US 11/499,887. In this disclosure a set of widgets can be managed on a desktop through use r inp ut o f c o nfig ura tio n information and synchronized with a data source. The widgets sets of two distinct devices may be synchronized with one another. Some widgets, e.g. a news, weather or traffic widgets, may need a periodic synchronization with a data source to update the displayed information. For example, a news widget needs an update to display the latest news, a mail box widget needs to synchronize with a mail server to give an up to date status ofa user's mailbox. These content updates are limited by essence because the content updates are linked to what the data source may provide. Furthermore, the update may be periodic, e ithe r c o ntro lie d by the end device itself of the widget module. They may also be triggered by the data source whenever an update is available.
Another example is described in Apple US 11/429,492. The proposed widget platform is designed to allow users to select widgets, typically from an online source and subsequently configured the selected widgets once for display. A widget engine in this context is responsible for the execution and display of the widgets. When the engine is operational, no dynamic widget control is performed. Each widget operates independently with a data source such as a web service. Only through manual intervention by the userare widgets removed from the display. This is achieved through a graphical user interface with e xp Hc it b utto ns and graphical objects that allow widgets to be incorporated in the final display or not. Likewise manual intervention through a graphical user interface is re quired for each widget to modify a widget's preferences.
Both these examples deal with content adaptations. Content adaptation for mo bile handsets deals with mechanisms that determine the devices physical characteristics, in particular screen width, height and bit depth, as well other resources, to determine how to shape the content to fit the device. Mobile content adaptation can occur either on the device, or alternatively in the network prior to being accessed by the device.
Tb date, it is not possible to activate, or deactivate, a set of widgets displayed on a GUIbased upon preferences. Furthermore, it is neither possible to adapta widget presentation based onthe contextual information of the device they are displayed on. Content adaptation is still constrained to the device physical characteristics. It would be also highly desirable if the managementof the widgets could be performed without user intervention.
There is still a need today for an improved management of the set of widgets displayed on a GUI There is a further need for managing the set of widgets with no userinput.
SlMMAKT OFTHE FKISENTSYSTEM AND MEIHOEfc
It is an object of the present system, processor and method to overcome disadvantages and/ormake improvements in the prior art.
Tb that extent, the present method proposes a method formanaging a set of widgets displayed on the graphical user interface (GUI) of a device, said method comprising the acts of:
- receiving contextual data from the device, -querying with the received contextual data a repository of widget configurations for the set of widgets, said widgets configura tions be ing described in said re p o sito ry a s func tio ns o f the possible contextual data values,
-displaying the set of widgets using the configuration that match the re c e ive d c o nte xtua 1 info rma tio n.
Thanks to the present method, an automatic management and control of a plurality of widgets is permitted on a device though the definition of context b a se d se Ie c tio n me c ha nisms. This me tho d is p a rtic ula rly re Ie va nt to sma 11 sc re e n mobile deviceswitha p lura lity o f wid g e ts. The controlofthe widgets is achieved through the use of predefined rules - which correspond to the widget configurations - that determine individual widget behavior as functions of the device's contextual data.
The user's experience with widgets is improved through the combination of multiple widget selection and individual widget preferences on various GUIs, such as, but not limited to, small sere en devices.
Aprocessorto manage widgets displayed on the graphical user interface (GUD of a device is also described hereafter. In one embodiment of the present processor, said processor comprising:
- a portion configured to receive contextual data from the device, -a portion for querying with the received contextual data a repository of widget configurations for the set of widgets, said widgets configurations being described in said re p o sito ry a s func tio ns o f the possible contextual data values,
-a portion configured to display the set of widgets using the configuration thatmatchthe received contextualdata. The present invention also relates to a computer program comprising instructions that cause a computerto implement the present method, as well as a GUIc o up led to the present processor. BHEFDESCHPIION OFTHE DRAWINGS:
The present system and method are explained in further detail, and by way of example, with referenc e to the accompanying drawings wherein:
FlG.1 shows an exemplary embodiment of the system according to the inve ntio n,
FlG.2 shows a flow chart illustrating how the state of a set of widgets may shift a c cording to an exemplary embodiment of the present method,
FlG.3 shows a detailed flow chart illustrating how the preference module selects configuration settings for the set of widgets according to the exemplary embodiment of the present method,
FIG. 4 shows an exemplary illustration of the widgets content shift according to an additional embodiment of the present method,
FIG.5 shows a mobile handset with a display illustrating a browser with active widget icons, FIG.6 shows a detail of the mobile display with a possible three by three widget icon layout, and;
FIG.7 shows a time line illustrating the potential widgets displayed within a Weekday AM, Weekday PM cycle combined with weekend cycle.
DEIAIIED DESCKIPΠON OFTHE FBESBNTSYSIBVI AND MEIHOD:
The following are descriptions of exemplary embodiments that when taken in c o njunc tio n with the drawings will demonstrate the above noted featuresand advantages, and introduce further ones.
In the following description, for purposes of explanation rather than limitation, specific details are set forth such as architecture, interfaces, techniques, etc ., for illustration. However, it willbe apparent to those of ordinary skill in the art that other embodiments that depart from these details would still be understood to be within the scope of the appended claims.
For example, the system and method described therein allows a unique personalized experience forthe user. The system willbe described hereafterin its application to a widget server with which a mobile device (such as a cellular phone) interacts. The man skilled in the art will notice that this is not the sole embodiment possible, and that the system and method according to the invention may be completely implemented on a user or telecommunication device (or client device) such as a personal computer, a PDA, a phone, or the likes. The different modules may also be hosted by separate servers and accessible over a network.
Moreover, forthe purpose of clarity, detailed descriptions of well-known devices, systems, and methods are omitted so as not to obscure the description of the present system. A widget generally refers to the application itself, while a widget icon is its representation on the GUI Forthe sake o f simp Hc ity, wid g e t will also be used to refer to the widget icon. In addition, it should be expressly understood that the drawings are included for illustrative purposes and do not represent the scope of the present system. Unless specified otherwise, the exemplary embodiment will be described hereafter in the context of a mobile device interacting with a distant widget server.
FlG.1 shows an exemplary embodiment of the system according to the invention. A electronic or telecommunication device 100 comprising a user interface, like a GUI, is used by an end-user to display a set of widgets on said inte rfa c e . In the exemplary illustration of FlG.1, the device is a mobile equipment or handset. Such a light weight (Le. with limited C e ntra 1 Pro c e ssing Unit) mobile device may be equipped with a web browser, Le. a software application that enables a user of the device to display and interact with text, images, videos, music and other information comprised on a webpage built by a website the device may connect to. Such a website is generally hosted by a server accessible through a network such as e.g. the World Wide Web or through a local are a network (LAN).
The system according to the exemplary embodiment of FlG. 1 further comprises a widget module or server 110 responsible for managing the set of widgets displayed on the GUI of the device. Widget module 110 is also responsible for providing the widget content to device 100. Widget server 110 maybe seen as a web server responsible for serving the widget framework and widget update data to the device 100. Once a widget webpage, as seen for example in the illustration of FIG.6, is built by widget server 110, it is downloaded to the mobile equipment and displayed on its GUI As any known webpage, the widgets that will be displayed by the GUImaybe comprised in the downloaded webpage, or hosted by the device itself. The various widgets implementations that exist today and that may be used by widget module 110 to display the set of widgets are beyond the scope of the present specification.
Device 100 is adapted to collect and forward to the widget module 110 c o ntextual information about said device. Bv contextual information, one may understand any parameter describing o r c ha ra c te rizing the present state of the device. This may include its location (when the device can track its position), time, temperature, ... This could include forexample, but not limited to, the state of its memory, the type of networkit is connected to, the state o f its b a tte ry, ...
Tb each widget corresponds configuration settings or preferences, which allow the control and adaptation of the widget, and the information it will display. The configuration settings, depending of their values, may cause the widget to be active or not (Le. displayed on the GUIornot), to display different types of content, ... In the present system, the configuration settings for each widget available to the device 100 are context-based configurations, Le. they are defined as functions of the possible values of the device 100 contextual information or data. These settings are stored in a preference repository 125, e.g. a relationaldatabase. For example, the active orinactive state of a widget may be defined as a func tio n o f the c o ntextual info rma tio n. In other words, a widget maybe rendered active orinactive based on the device contextual information. When for example the contextual information is the time, the widget may be active during this time interval of the day, and inactive during this o the r time . Therefore, the active /inactive state of a widget may be defined in repository 125 as a function of the time, Io c ation, or any c ontextual information device 100 may monitor. Fora news widget, the content displayed may be configured to vary during the day, displaying general news in the morning for example, and sports news in the evening. In the present system, widget server 110, once it has collected the contextual information from the device 100, is arranged to query repository 125 with sa id c o nte xtua 1 info rma tio n. Using the c o nfig ura tio n se tting s tha t c o rre sp o nd to, Le. match the received contextual data, widget server 110 may build a webpage with the widgets operating according to the updated widget settings matching the present conte xtua linfo rma tion of the device.
FlG. 7 illustrates an example of a GUI of a device 100 performing an exemplary embodiment of the method according to the invention. In this example, a series or set of widgets, have been selected by a user. These widgets are namely: - a weatherwidget,
- a news widget, that may display headline news, sports news, or business news,
- a stock market widget
- a traffic widget, - a mail widget,
- a search box widget,
- a game widget are displayed on .
A set of widgets may be seen as the widgets of interest to the end-user. He/she may at any time update the set of widgets by removing or adding new widgets, and defining configurations settings for the added widgets. As many widgets may be of interest to a user, the p re se nt syste m and method allow fora display of only the most relevant widgets to the users, taking into account his/her varying interest that are expressed as functions of the device contextual information. Furthermore and conversely to what is known in the prior art, the present system allows for an update of the displayed widget content that goes beyond the simple synchronization with a data source.
The configuration settings of these widgets may be defined for example as a function of the time and the location of the mobile handset in repository 125. Thus the configuration settings of the news widget may be defined so that the news widget is configured to display general news in the morning of a weekday, business news in the afternoon of a weekday, and sports news on a weekend from the same data source. The configuration settings of the news widget allows to synchronize this widget with difference sources depending in this example on the time of the day and of the week. In the present system, the synchronization with a data source is thus based on the contextual information of the end device.
In another example, the weather widget preferences are defined so that this widget is configured to be active and synchronize the weather information fora different region depending on the day of the week. A user traveling every weekend to his/her country house may want to have his/her city weather displayed on weekdays, and his/her country house weather starting on Friday to prepare for his/her weekend. The traffic widget may be configured to display only on weekdays morning the road traffic when the user's commutes to work or whenthe usergoesto his c o untry ho me onweekends.
As the widget module 110 received the contextual information from device 100, here in this example location and time, it collects from repository 125 the configuration se tting s fo r the set of widgets here above, and configure the widgets accordingly. As seen on FIG. 7, from left to right, the widget news displays headline news on weekdays mornings, business news on weekdays evenings and sports news in the weekends. The weather widget, active on weekdays, becomes inactive on weekends.
In the exemplary illustration of FlG. 1, widget module 110 may query directly preference repository 125 with the device contextual information (dotted line in FIG. 1). Widget module 110 is then arranged both to retrieve the right preferences from repository 125 and manage and display the set of widgets using said preferences.
As illustrated in the example of FlG. 1, widget module 110 may query indirectly preference repository 125, the retrieval of the right preferences being handled by a separate module 120, or preference module (as seen in straight lines in FlG.1). Preference module 120 may be a preference server, Le. a web service responsible for providing to widget server 110 the configuration settings matching the device contextual information. Widget server 110 and preference server 120 may be in this example two separate servers interacting over a ne two rk.
In order to define the preferences according to the possible values of a device contextual information, a user may interact with the preference module 120, which is also responsible forproviding a mechanism through which users can maintain and/or update context-based configuration setting fora selected set of widgets. A preference editor 127 may be used by a user to interact with preference module 120 and modify the configuration settings. The preference editor may be hosted by device 100 oravailable on the preference module 120.
Referring again to the example of FlG.7, a user may access with his/her device 100 the preference module 120, and edit the set of widgets preferences using preference editor 127. He/she may set the weather widget to be active only on weekday mornings, or define the news widget content depending on the time of the day and the week. The preference module may also be accessed from a device other than device 100 used to display the set of widgets. A desktop computer may be for instance used to access the preference module 120 to edit and modify the widget preferences.
The illustration of FIG. 1 corresponds to web based embodiment of the present system. Other implementations are readily available to the man skilled in the art. As mentioned earlier the widget and preference modules may be part of the same module. The widget module maybe a client to the device 100, while the preference module 120 is a distant server. Conversely, the preference module may be a client to the device 100 while the widget module 110 is a distant server. The maintenance and update of the configuration settings and the retrieval of the right configuration settings, two functions handled by preference module 120 in the illustration in straight lines in FlG. 1 may also be handled by separate modules. Other combinations of the various functions illustrated here above are also within the scope of the present system.
Device 100 may also be any web browser-based platform such as a desktop computer or an independent unit hosting most if not all the different modules of the present system. The ace ess to the network may be wireless or not, device 100 being equipped with the right communication interfaces according to ace ess the network.
The p re se nt syste m and method allow fora context shifting of the widget set displayed on the device 100, Le. a shifting based on the contextual data of the device. As seen before the shifting may be a shift between the active and inactive state of a widget, here after referred to as a state shift, or a shift in the content displayed on the GUI, here after referred to as a content shift. An embodiment of the present method is illustrated in FlG.2 for the state or content shift. The method is illustrated with the preference module and the widget module as separate modules. Device 100 is assumed to display a series or set of widgets as illustrated in the example of in FlG.6. In this example only 3 widgets are active, Le. actively displayed. The exemplary GUI 610 has 9 possible spots to display widgets Wl to W9, with 6 empty through browser 620. Selecting the widget will allow the whole widget to be displayed on the mobile display, for an enhanced and details viewing of the widget information. The end userisalso assumed to have selected a set of widgets for his/her device, and define the context based configuration se tting s fo r the selected widgets through the preference editor mentioned earlier on.
In a preliminary act 200, the end device collects contextual information or data about its present state. This may include location, time, ... as mentioned before. Act 200 may be performed on a regular basis, or whenever one of the monitored contextual parameter varies beyond a given range. The sampling of the different parameters may also vary from one parameter to the other, depending e.g. on its nature. Device 100 then forwards the contextual information to the widget module 110. The forwarded data may be limited to e.g. the parameters that triggered the sampling, the parameters the value of which varied from the previous sampling or all parameters.
In a further act 210, the widget module, in order to update the widget page, queries the preference module 120 with the received contextual information, to retrieve updated preferences for the currently displayed set of widgets.
In a further act 220 of the present method, the preference server retrieves the configuration settings for the set of widgets that apply (Le. correspond) to the received contextual information. An update of the set of widgets preferences is thus achieved. Depending on how the information is organized in preference repository 125, preference module 120 may browse repository 125 by widget, orby contextual parameter, orany suitable entry. In otherwords, in act 220, preference module evaluates end device context against the context based configuration settings, which may be seen as a set of defined rules. The identified preferences are forwarded to the widgetmodule in a further act230, so thatthe widgetmodule may update the set of widgets accordingly , e.g. activating or deactivating a numberof widgets (state shift) and/or changing the rendered information (content shift). In other words, preference module returns to the widget module a context-selected set of response data. This returned data includes the widgets themselves (Le. the active ones), as well as the underlying information the widgets use fo r g e ne ra ting the display presented to the end-user. In the exemplary embodiment of a widget server, an updated widget page is built using the identified preferences. In a final act 240, widget module 110 sends the updated widget page for a further display on the end device. In the here above illustration, the widget themselves, Le. the widget code is returned. In order to limit the data transfer in this act, in an additional embodiment of the present method, the widget code willbe transferred only for a widget which becomes active in the updated widget page. For already running widgets, as only the configuration may change, the data transfer may be limited to the new set of preferences, the update being performed on the client side (end device) or on the widget module.
In repository 125, the configuration settings for each widget are stored as func tio ns o f the possible values of the device contextual information. One possible way of storing the settings as functions of the contextual data may be to first define intervals -orranges-ofvaluesfo reach parameter characterizing the contextual information of the device. The different intervals are not necessarily contiguous as illustrated here after. An example implementation of various time ranges foruse in time-based preferences is shown here below in Table 1:
Figure imgf000016_0001
Figure imgf000017_0001
Table 1: An example time range set
wherein n/x-y is defined as: n day of a week(0 to 6) x and y times of the day in 0000 format (e.g.1800 stands for 18h00) x-y interval of a time in a day
For each widget, the configuration settings may be expressed according to each parameter defined intervals. In repository 125, the preferences may be organized by widgets and each parameter interval. Thus each configuration setting of a widget may be divided into preference sets, each preference set listing the widget configuration data valid forthe para meter interval attached to said preference set. In orderto facilitate the retrieval of the right configuration settings, the information may be sorted out in repository 125 mainly by the parameter intervals, Le. for each preference subset, the configuration data for all the widgets is defined. Other organization of the c o nfig ura tio n se tting s sto re d in repository 125 are readily available to the man skilled in the art.
An example of configuration settings is illustrated here below, it correspond to the traffic , stock and weather widgets that canbe seenin FlG.6 in an exemplary illustration of a mobile display. Their configuration is to vary depending on the moment of the week, namely on weekdays in the morning (weekday AM), weekdays in the afternoon (weekday PM) and weekends, these intervals corresponding to the definition illustrated in Table 1. Four preference subsets are available, corresponding to these three intervals and one default subset. Each subset comprises the widget name, class (here corresponding to a Javascript class), and path to retrieve the widget itself. The configuration data is also provided for each widget, e.g. for the weather widget, it may be different weather locations to display depending on the time interval, for the traffic, it may be a different itinerary to display, or simply the traffic in the vicinity of the end device actual location, and for the stock widget a list o f sto c ks to monitor. As nine positions are available on the mobile display in FlG.6, nine entries are provided for the widget names, classes and paths, "" c orresponding to an empty orunused position. In the example here after, the configuration is set so that the weather, stock and traffic widgets are on display during the weekdays, AM and PM, the display changing to the weatherand sports widgets during the weekend (Le. only two widget icons used).
* (Default) ({"name":"WidgetName", "settings":
("weatherd", "stockd", "trafficd", nil mi mi "",' ""/'")},
{"name":"WidgetClass", "settings":
("weatherWidget", "stockWidget", "traffic Widget",
{"nameM:MWidgetPath", "settings":
("../weather", "../stock", "../traffic", mi mi mi ) ) ) t,t,; t,t,; „„)})
* (Weekday AM) ({"name":"WidgetName", "settings":
("weatherd", "stockd", "trafficd", mi mi mi ) ) ) mi mi
{"name":"WidgetClass", "settings": ("weatherWidget", "stockWidget", "traffic Widget", mi mi mi ) i i mi mi '"Λ\
{"name":"WidgetPath", "settings":
("../weather", "../stock", "../traffic", , , , t,t,; t,t,; „„)})
* (Weekday PM) ({"name":"WidgetName", "settings":
("weatherd", "stockd", "trafficd", )}
{"name":"WidgetClass", "settings":
("weatherWidget", "stockWidget", "traffic Widget", {"name":"WidgetPath", "settings":
("../weather", "../stock", "../traffic", t,t,; t,t,; „„)})
* (Weekend)
({"name":"WidgetName", "settings": ("weatherd", "mlbd", "", i 1n^ "" > "" > "" > )}
{"name":"WidgetClass", "settings":
("weatherWidget", "mlbWidget", "",
15 "",' ""/"')},
{"name":"WidgetPath", "settings": ("../weather", "../mlb", "",
"", "", "")})
20
Depending on how the information is organized, preference module may browse repository 125 by widget first for all the widgets comprises in the set of widgets, and then by parameter intervals. F the information is organized mainly by the parameter intervals, the need to browse widget after widget is no longer
25 needed.
FlG. 3 shows an exemplary illustration of act 220 for the time parameter. The widget configuration settings may be defined in the preference re p o sito ry fo r each time range listed here above. In a preliminary act 300, preference module selects a first p re fe re nc e subset corresponding to a first time intervaL h a further
30 act 310, preference module checks if the selected preference subset apply to the current time of the end device, Le. if the current time is comprised in the time interval of the selected sub se t. F so , the selected preference subset is retained in a furtheract 320 as the subsequent configuration of the set of widgets. Fnot, in a further act 330, the preference module ve rifie s if mo re subsetsare available, if so,
35 it selects the next preference subset in the configuration settings in an act 340 and proceeds again with act 310. if no more subset are available aschecked in act 330, the preference module proceeds with retaining the default subset in a subsequent act 350. The browsing of the preference subsets ends in a further act 360 sub sequent to act 350 or 320.
Depending on how repository 125 is organized, preference module 120 may repeat acts 300 to 360 for each widget. The widget module may even update the widget display on a widget after widget basis. In an alternative embodiment of the present method, preference module performs these acts only once if each preference subset comprises configuration data forthe whole set of widgets.
FlG. 4 shows an exemplary illustration of the widgets content shift, once the updated configuration settings have been retrieved by the preference server in a preliminary act 400. In a further act 410, widget module checks among the active widgets the one that will require a content update. In a further act 420, the updated content is synchronized with the relevant data sources, e.g. web site s for news widgets. With the updated configurations settings and content, widget module may proceed with building the update widget page in a subsequent act 430, and send this page fora further upload by the end device for display in act 440.
Tb date mobile web content is typically modified to render web pages onto small screens. For mobile applications a wide range of techniques can be used to adapt the content. Some implementations repurpose content by, for example, eliminating tables and scaling images. These techniques are commonly known as small screen rendering (SSR). Such content adaptation can occur in the network, or Io c ally on the device to minimize bandwidth usage.
Content adaptation in this context requires identifying the characteristics of the device because content displays differently on various devices. A HTTP request header is one mechanism by which device characteristics can be determined. HTTP headers are name /value pairs that appearin both request and response messages. The name of the header is separated from the value by a single colon, for example: User- Agent: MoziUa/4.0 (compatible; MSIE 6.0; Windows NT 5.1) Provides a header: User-Agent whose value is Mozϋla/4.0 (compatible; MSIE 6.0; Windows NT 5.1). The purpose of this particular header is to supply the web server with information about the type of browser making the request. A c o mp Ie te d e fϊnitio n o f this a nd o the r c o mmo nly e nc o unte re d HTTP headers can be found in the World Wide Web consortium (W3C) HTTP 1.1 specification. Such techniques are widely used to adapt content.
The present system and method extend the content adaptation by introducing a new method for a dap ting content on a device.
The state shift obviates the need to scroll though lists of widgets because the time based preferences (or other parameter based preferences) allow pre- selection of widgets to take place. Even a small number of mobile widgets can take up most of the available screen real-estate resulting in a poor user experience that makes it hard to identify the desired widget. State shift automatically determines what widget to display from a plurality of widgets based on a defined set of rules identifying whetherto display widgets to the user. The present system allows the c ontrol of when and forhow long a widget is displayed as well as the control of what content should be presented. For example, a traffic widget for a journey home can be displayed ten minutes before leaving the office, while during the day it can be suppressed allowing other widgets to be displayed. This example is further illustrated in FIG.6. Furthermore, the content shift provides a unique mechanism for the display of a single widget. Through the content shift, widgets are able to use contextual information, including but not limited to current time and location of the display device, to tailor displayed content. This capability results in the presentation of information that is relevant to the user at all times. Context aware content display can be accomplished through the use of context-based widget preferences. For example, a news feed generated from a RSS widget could display current world news in the morning, stock market reports at noon and finally a sport feed at the end of the day. With existing widget technology this can only be achieved by manually setting the preferences for each individual widget to resetthe RSSchanneL The present system allows context aware widget display without modifying the core code of the widget. Instead, the widget module controls when and how to display widgets by evaluating end device context against a set of defined rules on a preference module and returning to the widget display device a context-selected set of response data. This returned data may include the widgets themselves, aswellasthe underlying information the widgets use for generating the display presented to the end-user. As seen before, forthe widgets which are already activated in the GUI, the returned data may only include the updated preferences. In some respects the present system is an additional layer of widget management controL
When the monitored contextual information comprises the device time, various granularity may be defined. As time elapses through the week and day, new applications will appear, some will change their appearance, while others are suppressed from view. The automated control of a mobile device graphical use r inte rfa c e can dramatically improve the experience on small devices by presenting only those widgets though a userpreference configuration.
Of course, it is to be appreciated that any one of the above embodiments or methods may be combined with one or more other embodiments and/or methods or be separated and/or performed amongst separate devices or device portions in accordance with the present system.
Enally, the above -discussion is intended to be merely illustrative of the present system and should not be construed as limiting the appended claims to any particular embodiment or group of embodiments. Thus, while the present system has been described with reference to exemplary embodiments, it should also be appreciated that numerous modifications and alternative embodiments may be devised by those having ordinary skill in the art without departing from the broader and intended spirit and scope of the present system as set forth in the claims that folio w.
The focus of the illustrations has been on the development of a web- based widget module, using mini-applications that run as a browser. Tb thisend, many of the implementation of these illustrations may leverage well defined Web standards of XHIMLLl, CSS2.1, DOM and JavaScript.
A web standards-based widget approach can be contrasted to applications that run on devices that are compiled for a specific target architectures, for example a windows DLL (dynamic a Uy linked library) or a Java application. Other embodiments may be available within the scope of the present system. AHmodules, and their re Ia ted functions may be stored in a single end device, like a mobile phone or a computer. The selection of the widgets of interest to a user, as well as the type of editor he/she may use to configure the context based p re fere nee sis beyond the scope of the present system.
While the source code, or markup that defines a widget, is an area of some debate within the industry, it is not essential to the novelty of the present system. It is possible to manage widgets using the method and techniques described in the present system and method. The present invention may be implemented through a processor hosted by the telecommunication device 100, this processor being configured to manage a set of widgets displayed on the graphical user interface (GUD of said device 100, said processor comprising:
- a portion configured to receive contextual data from the device, - a portion for querying with the received contextual data a repository of widget configurations for the set of widgets, said widgets configurations being described in said re p o sito ry a s func tio ns o f the possible contextual data values,
- a portion configured to display the set of widgets on the GUI using the configuration that mate he s the received contextual data. An exemplary embodiment of the telecommunication device 100 may comprise indeed a processor operationally coupled to a memory, a display or GUI, a userinput device and one ormore interface devices. The memory may be any type of device for storing programming application data, such as to support data analysis, as well as other data, such as performance data, end user subscription data, or else. The programming application data and other data are received by the processor for configuring the processor to perform operation acts in accordance with the present method. The operation acts may include controlling the GUI to display the set of widgets, or querying with the device contextual data a repository of widget configurations for the set of widgets. The user input may include a keyboard, mouse, trackball, or other device, such as a touch sensitive display, or the likes. The user input device is operable for interacting with the processor including interaction within the memory of the device, and/orotherelements of the present system.
The memory may be one single memory storing the application program to perform the acts of the present method the repository of widget configurations when stored on the device itself. In an alternative embodiment of the present system, the re p o sito ry fo r sto ring the widget configurations may be a distinct database operatively coupled to the processor, as illustrated in the exemplary embodiment of FlG.1 with preference repository 125. Moreover, the term "memory" should be construed broadly enough to encompass any information able to be read from or written to an address in the addressable space accessible by a processor. With this definition, information on a network is still within the memory as, for instance, the processormay retrieve the information from the networkforoperation in accordance with the present system. Furthermore, processormay forinstance comprise severalparts orportions, such as a portion configured to receive contextual data from the device, and a portion for querying with the received contextual data a repository of widget configurations for the set of widgets. These portions may themselves be further divided in subparts. Clearly the processor, memory, GUI, user input device, and/ or interface device may all or partly be a portion of a c o mp ute r syste m or other device, such as a server. Furthermore, the present method is particularly suited to be carried out by a computer software program, such program containing modules corresponding to one or more of the individual steps or acts described and/or envisioned by the present system. Such program may of course be embodied in a computer-readable medium, such as an integrated chip, a peripheral device or memory, such as the memory and/or other memory coupled to the processor. The section headings included herein are intended to facilitate a review but are notintended to limit the scope of the present system. Accordingly, the specification and drawings are to be regarded in an illustrative manner and are notintended to limit the scope ofthe appended claims.
In interpreting the appended claims, it should be understood that: a) the word "comprising" does not exclude the presence of other e Ie me nts o r a c ts tha n tho se liste d in a g ive n c Ia im ; b) the word "a" or "an" preceding an element does not exclude the presence of a plurality of such elements; c ) a ny re fe re nc e sig ns in the claimsdo not limit the ir sc o p e ; d) several "means" may be represented by the same item orhardware or software implemented structure or function; e) any of the disclosed elements may be comprised of hardware portions (e.g., including discrete and integrated electronic circuitry), software portions (e.g., computer programming), and any combination thereof; f) hardware portions may be comprised of one or both of analog and digital portions; g) any ofthe disclosed devices or portions thereof may be combined togetherorseparated into furthe r p o rtio ns unless specifically stated otherwise; h) no specific sequence of acts or steps is intended to be required unle ss sp e c ific ally indie ate d ; and i) the term "plurality of an element includes two or more of the claimed element, and does not imply any particular range of number of elements; that is, a plurality of elements may be as few as two elements, and may include an immeasurable number of elements.

Claims

CIAMSWha tisclaimed is:
1. A method formanaging a set of widgets displayed on the graphical user interface (GUD of a device, said method comprising the acts of:
- receiving contextual data from the device,
-querying with the received contextual data a repository of widget configurations for the set of widgets, said widgets configura tions be ing described in said re p o sito ry a s func tio ns o f the possible contextual data values, -displaying the set of widgets on the GUI using the configuration that matchesthe received contextual data.
2. A method according to claim 1, wherein the contextual data comprises the device time.
3. A method according to claim 1, wherein the contextual data comprises the device location.
4. A method according to claim 1, wherein the widget configurations comprise an a ctive /inactive state as a func tio n o f the possible contextual data values.
5. A method according to claim 1, wherein the possible contextual data values are divided into intervals of possible values.
6. A method according to the previous claim 5, wherein the widget configurations is stored in the repository as functions of the intervals of possible values.
7. A processor configured to manage a set of widgets displayed on the graphical user interface (GUD of a device, said processor comprising:
- a portion configured to receive contextual data from the device, -a portion for querying with the received contextual data a repository of 5 widget configurations for the set of widgets, said widgets configurations being described in said re p o sito ry a s func tio ns o f the possible contextual data values, -a portion configured to display the set of widgets on the GUI using the configuration that mate he s the received contextualdata.
10 8. A processor according to claim 7, wherein the contextual data comprises the device time.
9. A processor according to claim 7, wherein the contextual data comprises the device location.
15
10. A processor according to claim 7, wherein the widget configurations comprise an a ctive /inactive state as a func tio n o f the possible contextualdata values.
20 11. A processor according to claim 7, wherein the possible contextualdata values are divided into intervals of possible values.
12. A processor according to the previous claim 11, wherein the widget configurations is stored in the repository as functions of the intervals of possible
25 values.
13. A computer readable carrier including computer program instructions that cause a computer to implement a method for managing a set of widgets displayed on the graphical user interface (GUI) according to one of the claims 1
30 to 6.
14. A graphical user interface coupled to the processor of anyone of the claims 7 to 12 to display a set of widgets.
15. A telecommunication device arranged to manage a set of widgets displayed on the graphical user interface (GUD of said device, the te Ie c o mmunic a tio n d e vie e be ing furthe r a rra ng e d to :
-acquire contextual data for the telecommunication device, -query with the aquired contextual data a repository of widget configurations for the set of widgets, said widgets configura tio ns be ing described in said re p o sito ry a s func tio ns o f the possible contextual data values,
-display the set of widgets on the GUI using the configuration that matchesthe received contextual data.
PCT/IB2008/055642 2007-11-14 2008-11-14 A system and method for managing widges WO2009063441A2 (en)

Priority Applications (2)

Application Number Priority Date Filing Date Title
EP08849954A EP2223207A2 (en) 2007-11-14 2008-11-14 A system and method for managing widges
US12/743,228 US20100257196A1 (en) 2007-11-14 2008-11-14 System and method for managing widgets

Applications Claiming Priority (2)

Application Number Priority Date Filing Date Title
US98799007P 2007-11-14 2007-11-14
US60/987,990 2007-11-14

Publications (2)

Publication Number Publication Date
WO2009063441A2 true WO2009063441A2 (en) 2009-05-22
WO2009063441A3 WO2009063441A3 (en) 2009-08-20

Family

ID=40639253

Family Applications (1)

Application Number Title Priority Date Filing Date
PCT/IB2008/055642 WO2009063441A2 (en) 2007-11-14 2008-11-14 A system and method for managing widges

Country Status (3)

Country Link
US (1) US20100257196A1 (en)
EP (1) EP2223207A2 (en)
WO (1) WO2009063441A2 (en)

Cited By (7)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
NO20093318A (en) * 2009-11-11 2010-12-13 Harald Amundsen Procedure, navigation and presentation system for widgets on Internet-enabled devices
JP2011045085A (en) * 2009-08-24 2011-03-03 Samsung Electronics Co Ltd Control widget providing method and device applied with the same
EP2320316A1 (en) * 2009-09-29 2011-05-11 Sap Ag A framework to support application context and rule based UI-control
CN102214079A (en) * 2010-04-07 2011-10-12 阿里巴巴集团控股有限公司 Method and device for displaying data of widget
EP2462700A2 (en) * 2009-08-07 2012-06-13 Samsung Electronics Co., Ltd. Portable terminal providing environment adapted to present situation and method for operating the same
EP2562640A1 (en) * 2010-06-09 2013-02-27 ZTE Corporation Method and device for processing widget system appearance
US9032315B2 (en) 2009-08-07 2015-05-12 Samsung Electronics Co., Ltd. Portable terminal reflecting user's environment and method for operating the same

Families Citing this family (169)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CA2704080C (en) 2001-07-26 2012-08-28 Irise System and process for cooperatively programming a simulation program of a computer application to be developed
US9360990B1 (en) * 2003-09-09 2016-06-07 James A. Roskind Location-based applications
US7752633B1 (en) 2005-03-14 2010-07-06 Seven Networks, Inc. Cross-platform event engine
US8510453B2 (en) 2007-03-21 2013-08-13 Samsung Electronics Co., Ltd. Framework for correlating content on a local network with information on an external network
US8935269B2 (en) 2006-12-04 2015-01-13 Samsung Electronics Co., Ltd. Method and apparatus for contextual search and query refinement on consumer electronics devices
US8554868B2 (en) 2007-01-05 2013-10-08 Yahoo! Inc. Simultaneous sharing communication interface
US8938465B2 (en) * 2008-09-10 2015-01-20 Samsung Electronics Co., Ltd. Method and system for utilizing packaged content sources to identify and provide information based on contextual information
US20110197165A1 (en) * 2010-02-05 2011-08-11 Vasily Filippov Methods and apparatus for organizing a collection of widgets on a mobile device display
US20110193857A1 (en) * 2010-02-05 2011-08-11 Vasily Filippov Methods and apparatus for rendering a collection of widgets on a mobile device display
WO2011126889A2 (en) 2010-03-30 2011-10-13 Seven Networks, Inc. 3d mobile user interface with configurable workspace management
US20110283209A1 (en) * 2010-05-13 2011-11-17 Rovi Technologies Corporation Systems and methods for sharing information between widgets operating on the same user equipment
US8954870B2 (en) * 2010-10-08 2015-02-10 Irise System and method for extending a visualization platform
WO2012103506A2 (en) * 2011-01-27 2012-08-02 Michael Luna Single action access to context specific content at a mobile device
US20120272156A1 (en) * 2011-04-22 2012-10-25 Kerger Kameron N Leveraging context to present content on a communication device
US9304668B2 (en) * 2011-06-28 2016-04-05 Nokia Technologies Oy Method and apparatus for customizing a display screen of a user interface
BR112014000615B1 (en) 2011-07-12 2021-07-13 Snap Inc METHOD TO SELECT VISUAL CONTENT EDITING FUNCTIONS, METHOD TO ADJUST VISUAL CONTENT, AND SYSTEM TO PROVIDE A PLURALITY OF VISUAL CONTENT EDITING FUNCTIONS
CA2883979A1 (en) * 2011-08-15 2013-02-21 Comigo Ltd. Methods and systems for creating and managing multi participant sessions
US20130194310A1 (en) * 2012-01-26 2013-08-01 General Instrument Corporation Automatically adaptation of application data responsive to an operating condition of a portable computing device
US11734712B2 (en) 2012-02-24 2023-08-22 Foursquare Labs, Inc. Attributing in-store visits to media consumption based on data collected from user devices
US8972357B2 (en) 2012-02-24 2015-03-03 Placed, Inc. System and method for data collection to validate location data
US10155168B2 (en) 2012-05-08 2018-12-18 Snap Inc. System and method for adaptable avatars
US9342618B2 (en) * 2012-06-04 2016-05-17 Sap Se Web application compositon and modification editor
JP2014036431A (en) * 2012-08-10 2014-02-24 Kyocera Corp Electronic device, control program, and display control method in electronic device
JP5932563B2 (en) * 2012-08-10 2016-06-08 京セラ株式会社 Electronic device, control program, and processing execution method in electronic device
US20150206349A1 (en) 2012-08-22 2015-07-23 Goldrun Corporation Augmented reality virtual content platform apparatuses, methods and systems
US8775972B2 (en) 2012-11-08 2014-07-08 Snapchat, Inc. Apparatus and method for single action control of social network profile access
US20140129934A1 (en) * 2012-11-08 2014-05-08 Microsoft Corporation Dynamic model-based management tooling
KR102062763B1 (en) 2012-12-07 2020-01-07 삼성전자주식회사 Method and system for providing information based on context, and computer readable recording medium thereof
US9747005B1 (en) * 2013-03-11 2017-08-29 Workday, Inc. Adaptive user interface
US9705831B2 (en) 2013-05-30 2017-07-11 Snap Inc. Apparatus and method for maintaining a message thread with opt-in permanence for entries
US9742713B2 (en) 2013-05-30 2017-08-22 Snap Inc. Apparatus and method for maintaining a message thread with opt-in permanence for entries
US10439972B1 (en) 2013-05-30 2019-10-08 Snap Inc. Apparatus and method for maintaining a message thread with opt-in permanence for entries
KR20150019795A (en) * 2013-08-16 2015-02-25 엘지전자 주식회사 Mobile terminal and method for controlling the same
US20150113451A1 (en) * 2013-10-23 2015-04-23 Steve Kopp Creation of widgets based on a current data context
US9083770B1 (en) 2013-11-26 2015-07-14 Snapchat, Inc. Method and system for integrating real time communication features in applications
CA2863124A1 (en) 2014-01-03 2015-07-03 Investel Capital Corporation User content sharing system and method with automated external content integration
US9628950B1 (en) 2014-01-12 2017-04-18 Investment Asset Holdings Llc Location-based messaging
US10082926B1 (en) 2014-02-21 2018-09-25 Snap Inc. Apparatus and method for alternate channel communication initiated through a common message thread
US8909725B1 (en) 2014-03-07 2014-12-09 Snapchat, Inc. Content delivery network for ephemeral objects
US9276886B1 (en) 2014-05-09 2016-03-01 Snapchat, Inc. Apparatus and method for dynamically configuring application component tiles
US9396354B1 (en) 2014-05-28 2016-07-19 Snapchat, Inc. Apparatus and method for automated privacy protection in distributed images
US9537811B2 (en) 2014-10-02 2017-01-03 Snap Inc. Ephemeral gallery of ephemeral messages
IL239237B (en) 2014-06-05 2018-12-31 Rotem Efrat Web document enhancement
US9113301B1 (en) 2014-06-13 2015-08-18 Snapchat, Inc. Geo-location based event gallery
US9225897B1 (en) 2014-07-07 2015-12-29 Snapchat, Inc. Apparatus and method for supplying content aware photo filters
US10055717B1 (en) 2014-08-22 2018-08-21 Snap Inc. Message processor with application prompts
US10423983B2 (en) 2014-09-16 2019-09-24 Snap Inc. Determining targeting information based on a predictive targeting model
US10824654B2 (en) 2014-09-18 2020-11-03 Snap Inc. Geolocation-based pictographs
US11216869B2 (en) 2014-09-23 2022-01-04 Snap Inc. User interface to augment an image using geolocation
US10284508B1 (en) 2014-10-02 2019-05-07 Snap Inc. Ephemeral gallery of ephemeral messages with opt-in permanence
US9015285B1 (en) 2014-11-12 2015-04-21 Snapchat, Inc. User interface for accessing media at a geographic location
US9854219B2 (en) 2014-12-19 2017-12-26 Snap Inc. Gallery of videos set to an audio time line
US9385983B1 (en) 2014-12-19 2016-07-05 Snapchat, Inc. Gallery of messages from individuals with a shared interest
US10311916B2 (en) 2014-12-19 2019-06-04 Snap Inc. Gallery of videos set to an audio time line
US9754355B2 (en) 2015-01-09 2017-09-05 Snap Inc. Object recognition based photo filters
US11388226B1 (en) 2015-01-13 2022-07-12 Snap Inc. Guided personal identity based actions
US10133705B1 (en) 2015-01-19 2018-11-20 Snap Inc. Multichannel system
US9521515B2 (en) 2015-01-26 2016-12-13 Mobli Technologies 2010 Ltd. Content request by location
US10223397B1 (en) 2015-03-13 2019-03-05 Snap Inc. Social graph based co-location of network users
US10616239B2 (en) 2015-03-18 2020-04-07 Snap Inc. Geo-fence authorization provisioning
US9692967B1 (en) 2015-03-23 2017-06-27 Snap Inc. Systems and methods for reducing boot time and power consumption in camera systems
BR112017020225B1 (en) * 2015-04-13 2023-02-23 Huawei Technologies Co., Ltd METHOD AND APPARATUS FOR DISPLAYING A TASK MANAGEMENT INTERFACE
US9881094B2 (en) 2015-05-05 2018-01-30 Snap Inc. Systems and methods for automated local story generation and curation
US10135949B1 (en) 2015-05-05 2018-11-20 Snap Inc. Systems and methods for story and sub-story navigation
US10993069B2 (en) 2015-07-16 2021-04-27 Snap Inc. Dynamically adaptive media content delivery
US10817898B2 (en) 2015-08-13 2020-10-27 Placed, Llc Determining exposures to content presented by physical objects
US9652896B1 (en) 2015-10-30 2017-05-16 Snap Inc. Image based tracking in augmented reality systems
US9984499B1 (en) 2015-11-30 2018-05-29 Snap Inc. Image and point cloud based tracking and in augmented reality systems
US10474321B2 (en) 2015-11-30 2019-11-12 Snap Inc. Network resource location linking and visual content sharing
US10354425B2 (en) 2015-12-18 2019-07-16 Snap Inc. Method and system for providing context relevant media augmentation
US10747504B2 (en) * 2016-02-01 2020-08-18 General Electric Company Context-based view service
US10285001B2 (en) 2016-02-26 2019-05-07 Snap Inc. Generation, curation, and presentation of media collections
US10679389B2 (en) 2016-02-26 2020-06-09 Snap Inc. Methods and systems for generation, curation, and presentation of media collections
US11023514B2 (en) 2016-02-26 2021-06-01 Snap Inc. Methods and systems for generation, curation, and presentation of media collections
US10339365B2 (en) 2016-03-31 2019-07-02 Snap Inc. Automated avatar generation
US11900418B2 (en) 2016-04-04 2024-02-13 Snap Inc. Mutable geo-fencing system
US11201981B1 (en) 2016-06-20 2021-12-14 Pipbin, Inc. System for notification of user accessibility of curated location-dependent content in an augmented estate
US10805696B1 (en) 2016-06-20 2020-10-13 Pipbin, Inc. System for recording and targeting tagged content of user interest
US11044393B1 (en) 2016-06-20 2021-06-22 Pipbin, Inc. System for curation and display of location-dependent augmented reality content in an augmented estate system
US11876941B1 (en) 2016-06-20 2024-01-16 Pipbin, Inc. Clickable augmented reality content manager, system, and network
US10638256B1 (en) 2016-06-20 2020-04-28 Pipbin, Inc. System for distribution and display of mobile targeted augmented reality content
US11785161B1 (en) 2016-06-20 2023-10-10 Pipbin, Inc. System for user accessibility of tagged curated augmented reality content
US10334134B1 (en) 2016-06-20 2019-06-25 Maximillian John Suiter Augmented real estate with location and chattel tagging system and apparatus for virtual diary, scrapbooking, game play, messaging, canvasing, advertising and social interaction
US10430838B1 (en) 2016-06-28 2019-10-01 Snap Inc. Methods and systems for generation, curation, and presentation of media collections with automated advertising
US9681265B1 (en) 2016-06-28 2017-06-13 Snap Inc. System to track engagement of media items
US10387514B1 (en) 2016-06-30 2019-08-20 Snap Inc. Automated content curation and communication
US10348662B2 (en) 2016-07-19 2019-07-09 Snap Inc. Generating customized electronic messaging graphics
US10410367B2 (en) 2016-08-30 2019-09-10 C3D Augmented Reality Solutions Ltd. Systems and methods for simulatenous localization and mapping
US10432559B2 (en) 2016-10-24 2019-10-01 Snap Inc. Generating and displaying customized avatars in electronic messages
CN109952610B (en) 2016-11-07 2021-01-08 斯纳普公司 Selective identification and ordering of image modifiers
US10203855B2 (en) 2016-12-09 2019-02-12 Snap Inc. Customized user-controlled media overlays
US11616745B2 (en) 2017-01-09 2023-03-28 Snap Inc. Contextual generation and selection of customized media content
US10454857B1 (en) 2017-01-23 2019-10-22 Snap Inc. Customized digital avatar accessories
US10915911B2 (en) 2017-02-03 2021-02-09 Snap Inc. System to determine a price-schedule to distribute media content
US11250075B1 (en) 2017-02-17 2022-02-15 Snap Inc. Searching social media content
US10319149B1 (en) 2017-02-17 2019-06-11 Snap Inc. Augmented reality anamorphosis system
US10074381B1 (en) 2017-02-20 2018-09-11 Snap Inc. Augmented reality speech balloon system
US10565795B2 (en) 2017-03-06 2020-02-18 Snap Inc. Virtual vision system
US10523625B1 (en) 2017-03-09 2019-12-31 Snap Inc. Restricted group content collection
US10581782B2 (en) 2017-03-27 2020-03-03 Snap Inc. Generating a stitched data stream
US10582277B2 (en) 2017-03-27 2020-03-03 Snap Inc. Generating a stitched data stream
US11170393B1 (en) 2017-04-11 2021-11-09 Snap Inc. System to calculate an engagement score of location based media content
US10387730B1 (en) 2017-04-20 2019-08-20 Snap Inc. Augmented reality typography personalization system
US10212541B1 (en) 2017-04-27 2019-02-19 Snap Inc. Selective location-based identity communication
KR102515132B1 (en) 2017-04-27 2023-03-28 스냅 인코포레이티드 A geographic level representation of a user's location on a social media platform
US11893647B2 (en) 2017-04-27 2024-02-06 Snap Inc. Location-based virtual avatars
US10467147B1 (en) 2017-04-28 2019-11-05 Snap Inc. Precaching unlockable data elements
US10803120B1 (en) 2017-05-31 2020-10-13 Snap Inc. Geolocation based playlists
US11475254B1 (en) 2017-09-08 2022-10-18 Snap Inc. Multimodal entity identification
US10740974B1 (en) 2017-09-15 2020-08-11 Snap Inc. Augmented reality system
US10499191B1 (en) 2017-10-09 2019-12-03 Snap Inc. Context sensitive presentation of content
US10573043B2 (en) 2017-10-30 2020-02-25 Snap Inc. Mobile-based cartographic control of display content
US11265273B1 (en) 2017-12-01 2022-03-01 Snap, Inc. Dynamic media overlay with smart widget
US11017173B1 (en) 2017-12-22 2021-05-25 Snap Inc. Named entity recognition visual context and caption data
US10678818B2 (en) 2018-01-03 2020-06-09 Snap Inc. Tag distribution visualization system
US11507614B1 (en) 2018-02-13 2022-11-22 Snap Inc. Icon based tagging
AU2018410087B2 (en) * 2018-02-20 2021-04-29 Tata Consultancy Services Limited A server controlled framework for controlling widgets of a tabular structure
US10885136B1 (en) 2018-02-28 2021-01-05 Snap Inc. Audience filtering system
US10979752B1 (en) 2018-02-28 2021-04-13 Snap Inc. Generating media content items based on location information
US10327096B1 (en) 2018-03-06 2019-06-18 Snap Inc. Geo-fence selection system
EP3766028A1 (en) 2018-03-14 2021-01-20 Snap Inc. Generating collectible items based on location information
US11163941B1 (en) 2018-03-30 2021-11-02 Snap Inc. Annotating a collection of media content items
US10219111B1 (en) 2018-04-18 2019-02-26 Snap Inc. Visitation tracking system
US10719202B2 (en) 2018-04-25 2020-07-21 Bank Of America Corporation System for dynamically rendering a graphical user interface
US10896197B1 (en) 2018-05-22 2021-01-19 Snap Inc. Event detection system
US10679393B2 (en) 2018-07-24 2020-06-09 Snap Inc. Conditional modification of augmented reality object
US10997760B2 (en) 2018-08-31 2021-05-04 Snap Inc. Augmented reality anthropomorphization system
US10671236B2 (en) * 2018-09-20 2020-06-02 Salesforce.Com, Inc. Stateful, contextual, and draggable embedded widget
US10698583B2 (en) 2018-09-28 2020-06-30 Snap Inc. Collaborative achievement interface
US10778623B1 (en) 2018-10-31 2020-09-15 Snap Inc. Messaging and gaming applications communication platform
US10939236B1 (en) 2018-11-30 2021-03-02 Snap Inc. Position service to determine relative position to map features
US11199957B1 (en) 2018-11-30 2021-12-14 Snap Inc. Generating customized avatars based on location information
US11032670B1 (en) 2019-01-14 2021-06-08 Snap Inc. Destination sharing in location sharing system
US10939246B1 (en) 2019-01-16 2021-03-02 Snap Inc. Location-based context information sharing in a messaging system
US11294936B1 (en) 2019-01-30 2022-04-05 Snap Inc. Adaptive spatial density based clustering
US10936066B1 (en) 2019-02-13 2021-03-02 Snap Inc. Sleep detection in a location sharing system
US10838599B2 (en) 2019-02-25 2020-11-17 Snap Inc. Custom media overlay system
US10964082B2 (en) 2019-02-26 2021-03-30 Snap Inc. Avatar based on weather
US10852918B1 (en) 2019-03-08 2020-12-01 Snap Inc. Contextual information in chat
US11868414B1 (en) 2019-03-14 2024-01-09 Snap Inc. Graph-based prediction for contact suggestion in a location sharing system
US11852554B1 (en) 2019-03-21 2023-12-26 Snap Inc. Barometer calibration in a location sharing system
US11249614B2 (en) 2019-03-28 2022-02-15 Snap Inc. Generating personalized map interface with enhanced icons
US10810782B1 (en) 2019-04-01 2020-10-20 Snap Inc. Semantic texture mapping system
US10582453B1 (en) 2019-05-30 2020-03-03 Snap Inc. Wearable device location systems architecture
US10560898B1 (en) 2019-05-30 2020-02-11 Snap Inc. Wearable device location systems
US10893385B1 (en) 2019-06-07 2021-01-12 Snap Inc. Detection of a physical collision between two client devices in a location sharing system
US11307747B2 (en) 2019-07-11 2022-04-19 Snap Inc. Edge gesture interface with smart interactions
US11821742B2 (en) 2019-09-26 2023-11-21 Snap Inc. Travel based notifications
US11218838B2 (en) 2019-10-31 2022-01-04 Snap Inc. Focused map-based context information surfacing
US11128715B1 (en) 2019-12-30 2021-09-21 Snap Inc. Physical friend proximity in chat
US11429618B2 (en) 2019-12-30 2022-08-30 Snap Inc. Surfacing augmented reality objects
US10880496B1 (en) 2019-12-30 2020-12-29 Snap Inc. Including video feed in message thread
US11343323B2 (en) 2019-12-31 2022-05-24 Snap Inc. Augmented reality objects registry
US11169658B2 (en) 2019-12-31 2021-11-09 Snap Inc. Combined map icon with action indicator
US11228551B1 (en) 2020-02-12 2022-01-18 Snap Inc. Multiple gateway message exchange
US11516167B2 (en) 2020-03-05 2022-11-29 Snap Inc. Storing data based on device location
US11188202B2 (en) * 2020-03-10 2021-11-30 Apple Inc. Devices, methods, and graphical user interfaces for interacting with user interface objects corresponding to applications
US11619501B2 (en) 2020-03-11 2023-04-04 Snap Inc. Avatar based on trip
US10956743B1 (en) 2020-03-27 2021-03-23 Snap Inc. Shared augmented reality system
US11430091B2 (en) 2020-03-27 2022-08-30 Snap Inc. Location mapping for large scale augmented-reality
US11314776B2 (en) 2020-06-15 2022-04-26 Snap Inc. Location sharing using friend list versions
US11503432B2 (en) 2020-06-15 2022-11-15 Snap Inc. Scalable real-time location sharing framework
US11290851B2 (en) 2020-06-15 2022-03-29 Snap Inc. Location sharing using offline and online objects
US11483267B2 (en) 2020-06-15 2022-10-25 Snap Inc. Location sharing using different rate-limited links
US11308327B2 (en) 2020-06-29 2022-04-19 Snap Inc. Providing travel-based augmented reality content with a captured image
US11349797B2 (en) 2020-08-31 2022-05-31 Snap Inc. Co-location connection service
US11606756B2 (en) 2021-03-29 2023-03-14 Snap Inc. Scheduling requests for location data
US11645324B2 (en) 2021-03-31 2023-05-09 Snap Inc. Location-based timeline media content system
US11829834B2 (en) 2021-10-29 2023-11-28 Snap Inc. Extended QR code

Citations (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20070022380A1 (en) * 2005-07-20 2007-01-25 Microsoft Corporation Context aware task page
US20070118813A1 (en) * 2005-11-18 2007-05-24 Scott Forstall Management of user interface elements in a display environment
US20070300185A1 (en) * 2006-06-27 2007-12-27 Microsoft Corporation Activity-centric adaptive user interface

Family Cites Families (5)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US7620737B2 (en) * 2002-12-12 2009-11-17 Xerox Corporation Methods, apparatus, and program products for abstract applications/components in a ubiquitous computing environment
JP2006526828A (en) * 2003-06-05 2006-11-24 スイス リインシュアランス カンパニー Uniform device-independent graphical user interface generation method and terminal
US8566732B2 (en) * 2004-06-25 2013-10-22 Apple Inc. Synchronization of widgets and dashboards
KR100886336B1 (en) * 2006-11-17 2009-03-02 삼성전자주식회사 Apparatus and Methods for managing the multimedia informations by which GUIs are constituted
US7778792B2 (en) * 2006-12-08 2010-08-17 Chumby Industries, Inc. Systems and methods for location, motion, and contact detection and tracking in a networked audiovisual device

Patent Citations (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20070022380A1 (en) * 2005-07-20 2007-01-25 Microsoft Corporation Context aware task page
US20070118813A1 (en) * 2005-11-18 2007-05-24 Scott Forstall Management of user interface elements in a display environment
US20070300185A1 (en) * 2006-06-27 2007-12-27 Microsoft Corporation Activity-centric adaptive user interface

Cited By (15)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US8971805B2 (en) 2009-08-07 2015-03-03 Samsung Electronics Co., Ltd. Portable terminal providing environment adapted to present situation and method for operating the same
US9032315B2 (en) 2009-08-07 2015-05-12 Samsung Electronics Co., Ltd. Portable terminal reflecting user's environment and method for operating the same
EP2462700A2 (en) * 2009-08-07 2012-06-13 Samsung Electronics Co., Ltd. Portable terminal providing environment adapted to present situation and method for operating the same
EP2462700A4 (en) * 2009-08-07 2013-01-23 Samsung Electronics Co Ltd Portable terminal providing environment adapted to present situation and method for operating the same
JP2011045085A (en) * 2009-08-24 2011-03-03 Samsung Electronics Co Ltd Control widget providing method and device applied with the same
EP2290954B1 (en) * 2009-08-24 2017-03-01 Samsung Electronics Co., Ltd. Method for providing control widget and device using the same
EP2320316A1 (en) * 2009-09-29 2011-05-11 Sap Ag A framework to support application context and rule based UI-control
WO2011059335A1 (en) 2009-11-11 2011-05-19 Harald Amundsen Method, navigation and display system for widgets on internet-enabled devices
US8736764B2 (en) 2009-11-11 2014-05-27 Harald Amundsen Method, navigation and display system for widgets on internet-enabled devices
NO20093318A (en) * 2009-11-11 2010-12-13 Harald Amundsen Procedure, navigation and presentation system for widgets on Internet-enabled devices
CN102214079A (en) * 2010-04-07 2011-10-12 阿里巴巴集团控股有限公司 Method and device for displaying data of widget
US20130067371A1 (en) * 2010-06-09 2013-03-14 Zte Corporation Method and device for processing widget system appearance
EP2562640A4 (en) * 2010-06-09 2013-11-20 Zte Corp Method and device for processing widget system appearance
KR101476023B1 (en) * 2010-06-09 2014-12-23 지티이 코포레이션 Method and device for processing widget system appearance
EP2562640A1 (en) * 2010-06-09 2013-02-27 ZTE Corporation Method and device for processing widget system appearance

Also Published As

Publication number Publication date
US20100257196A1 (en) 2010-10-07
WO2009063441A3 (en) 2009-08-20
EP2223207A2 (en) 2010-09-01

Similar Documents

Publication Publication Date Title
EP2223207A2 (en) A system and method for managing widges
US7873356B2 (en) Search interface for mobile devices
US9363338B2 (en) System and method for simultaneous display of multiple information sources
JP5204774B2 (en) System and method for providing electronic device users with dynamically selected media content in a social network environment
KR101161091B1 (en) Apparatus and methods for widget intercommunication in a wireless communication environment
US7769805B1 (en) Mobile device catalog and caching and architecture
US9880702B2 (en) Content structures and content navigation interfaces
Taraghi et al. Personal learning environment-a conceptual study.
US20150095820A1 (en) Service for generation of customizable display widgets
US20100241663A1 (en) Providing content items selected based on context
US20140026037A1 (en) Creating personalized networked documents
US20070239842A1 (en) System and method for provisioning a remote resource for an electronic device
WO2004049208A1 (en) Personalising content provided to a user
KR20050012881A (en) System for realtime rss/atom reader on web browser and method thereof
US20110257960A1 (en) Method and apparatus for context-indexed network resource sections
WO2011080379A1 (en) Method and apparatus for dynamically grouping items in applications
WO2007042987A1 (en) A mobile personalized information platform
Hinze et al. The challenge of creating cooperating mobile services: Experiences and lessons learned
CN102203709A (en) Displaying personalized information in a handheld device
KR100774848B1 (en) System and method for providing menu list
Ma et al. Service brick composition framework for smartphones
US9645706B2 (en) Generating and implementing localized jump lists
US8271885B2 (en) User interface customization using evaluation data
US11736427B2 (en) Integration of client applications with hosted applications
US20220253295A1 (en) Software widget installation on a client device

Legal Events

Date Code Title Description
121 Ep: the epo has been informed by wipo that ep was designated in this application

Ref document number: 08849954

Country of ref document: EP

Kind code of ref document: A2

WWE Wipo information: entry into national phase

Ref document number: 12743228

Country of ref document: US

NENP Non-entry into the national phase in:

Ref country code: DE

REEP Request for entry into the european phase

Ref document number: 2008849954

Country of ref document: EP

WWE Wipo information: entry into national phase

Ref document number: 2008849954

Country of ref document: EP