SYSTEM AND METHOD FOR CONFIGURATION OF CONTROLLING DEVICE FUNCTIONALITY

Abstract
A user interface of a hand-held device is provided with a widget which is activatable to cause the hand-held device to perform at least one action. The widget is created by a user selecting programming blocks from a library of pre-defined programming blocks where each programming block is graphically represented as a processing unit with at least one of an input and an output. User input is then provided to graphically interconnect selected ones of the inputs and outputs of the pre-defined, user selected programming blocks to thereby define the at least one action that is to be performed upon activation of the widget.
Description

Each of these applications are incorporated herein by reference in their entirety.


BACKGROUND

The following relates generally to controlling devices and, more particularly, to a configurable controlling device having an associated editor program for use in configuring, among other things, the user interface and functionality of the controlling device.


Editor programs for configuring a controlling device, such as a hand held remote control, are known in the art. For example, U.S. Pat. No. 6,211,870 illustrates and describes a controlling device which is programmable from a PC using an advanced, object-oriented user interface. More particularly, multiple user selectable screen objects may be created on the PC and transferred to the controlling device. The screen objects include screen layout and descriptions of soft keys to be displayed on a graphic display of the controlling device, as well as commands associated with the screen object, the soft keys and/or programmable keys on the remote control unit. The user may then select any of the screen objects once they have been transferred to the controlling device to control the operation of various appliances.


Similarly, PCT published application no. WO 00/39772 discloses a universal, programmable remote control device which has programming that enables an end-user to customize the remote control device through editing or programming of the control functionalities of the remote control device. The programming is achieved via a PC. In this manner, the control configuration created via an editor on the PC can be downloaded into the device. It is additionally disclosed that the PC has emulator software to test the configuration before downloading. It is to be understood that WO 00/39772 generally discloses the editor for the Philips' “Pronto” brand remote control.


Increasingly, such programmable controlling devices are utilized in applications which require adaptable functionality, i.e., an ability to dynamically modify the actions performed in response to user input based on variable parameters such as time, existing state of an appliance, previous action performed, etc., especially in environments which include networked and/or interactive appliances. While some known controlling devices and associated editor programs do provide limited methods for supporting such adaptable functionality, such programming of these controlling devices is tedious and error-prone.


SUMMARY

The following generally discloses an editor program for use in configuring a user interface of a controlling device, together with a configurable controlling device such as a hand-held remote control unit. The editor program allows a user to create on a personal computer for downloading to the controlling device a graphical user interface comprised of user interface pages having icons which icons, when activated on the controlling device, cause the controlling device to perform a function or series of functions, such as to transmit a command to an appliance, to change the user interface display, etc. The editor program provides, among other things, for selection and placement of icons onto user interface display pages, assignment of commands to function keys (both iconic and hard keys), assignment of backgrounds to user interface pages or groups of pages, creation of icon-activated, user-defined command sequences, pre-rendering of user interface pages prior to downloading of the user interface to the controlling device, etc. Advantageously, in an exemplary embodiment the user interface editor and the operating software of the controlling device may also support the definition and editing of n-state widgets, which are unitary GUI objects comprising one or more touch activated areas together with one or more display graphics (not necessarily in a one-for-one relationship) and which are capable of both initiating parameterized command functions in response to user or system inputs, as well as receiving and acting upon status responses or other data received from target appliances. The editor program may include features to facilitate flexible definition of the exact behavior, appearance, and functionality of such widget objects.


The various advantages, features, properties and relationships of this improved user interface editor and controlling device system will be obtained from the following detailed description and accompanying drawings which set forth illustrative embodiments which are indicative of the various ways in which the principles thereof may be employed.





BRIEF DESCRIPTION OF THE DRAWINGS

For use in better understanding the user interface editor and configuration system and related methods described hereinafter reference may be had to the following drawings in which:



FIG. 1 illustrates an exemplary home entertainment system in which the exemplary controlling devices may be utilized;



FIG. 2 illustrates a block diagram of components of an exemplary controlling device;



FIGS. 3
a and 3b illustrate exemplary editing systems which may be used to configure and download a controlling device configuration, including a user interface, to an exemplary controlling device;



FIG. 4 illustrates an exemplary home page graphical user interface (“GUI”) for a touch screen of a controlling device;



FIG. 5 illustrates an exemplary device selection page GUI for the touch screen of a controlling device;



FIG. 6 illustrates an exemplary device control page GUI for the touch screen of a controlling device;



FIG. 7 illustrates another exemplary device control page GUI for the touch screen of a controlling device;



FIG. 8 illustrates yet another exemplary device control page GUI for the touch screen of a controlling device;



FIG. 9 illustrates an exemplary PC-based editor which may be used to create the appearance and functionality of the exemplary GUI of FIG. 4;



FIG. 10 illustrates an exemplary group of programming blocks which may be used in the definition of widgets;



FIGS. 11
a and 11b illustrate the use of the programming blocks of FIG. 10 in a PC-based editor to create an exemplary widget;



FIG. 12 illustrates the use of the programming blocks of FIG. 10 in a PC-based editor to create a second exemplary widget;



FIGS. 13 and 14 illustrate the placement of the widget of FIGS. 11a and 11b into an exemplary control page GUI; and



FIG. 15 illustrates the subsequent execution and appearance of the control pages and widget programming after download into a controlling device.





DETAILED DESCRIPTION

The following discloses a controlling device having a face panel on which is carried a user interface activatable to cause transmission of at least one command to at least one appliance. Turning now to the figures, wherein like reference numerals refer to like elements, FIG. 1 illustrates an exemplary system including controllable appliances, such as a set top box (“STB”) 104, a DVD player 106, an audio amplifier/receiver 108, a television 102, a lighting fixture 110 with associated multilevel dimmer 114, and a surveillance camera 112 as well as a controlling device 100. The controlling device 100 is capable of transmitting commands to the appliances, using any convenient IR or RF, point-to-point or networked, protocol to cause the appliances to perform operational functions. By way of illustration without limitation, the controlling device of FIG. 1 may utilize uni- or bi-directional IR signaling 116, proprietary RF signaling 118 (e.g., Zwave), and/or standardized RF network signaling 120 (e.g., WiFi or Bluetooth) to communicate with the various target appliances. While illustrated in the context of a STB 104 with DVD player 106, audio system 108, television 102, lighting fixture 110 and camera 112 it is to be understood that controllable appliances can include, but are not limited to, televisions, VCRs, DVRs, DVD players, cable or satellite converter set-top boxes (STBs), amplifiers, media streaming devices, CD players, game consoles, home lighting, drapery controls, fans, HVAC systems, thermostats, door locks, security systems, personal computers, etc., and, as such, the instant exemplary disclosures are not intended to be limiting as to type or quantity of controllable appliances or equipment.


Turning now to FIG. 2, for use in transmitting command codes to one or more of the appliances, the controlling device 100 of the exemplary system may include, as needed for a particular application, a processor 200 coupled to a physically embodied, non-transient memory device (such as ROM memory 204, RAM memory 202, and/or a non-volatile memory 206), a key matrix 216 (e.g., physical buttons, a touch sensitive display with soft keys, or a combination thereof), an internal clock and timer 222, an IR (and/or RF) transmitter 208 for directly issuing commands to controlled appliances, one or more RF (and/or IR) wireless transmission and reception circuit(s) 210, 212 for issuing commands to controlled appliances via a network and/or transferring data or commands between the controlling device and other networked controlling devices or external computing devices such as a PC, a physical input/output interface 224 (e.g., USB interface) for use in directly transferring data between the controlling device and an external computing devices such as a PC, STB, etc., a means 218 to provide visual feedback to the user (e.g., LCD display or the like, which may underlay all or part of a touch sensitive portion of key matrix 216), a means 220 to provide audio feedback (speaker, buzzer, etc.) and a power supply 214 all as generally illustrated in FIG. 2. As will be understood by those of skill in the art, the memory device(s) may include executable instructions that are intended to be executed by the processor 200 to control the operation of the controlling device 100.


The non-volatile read/write memory 206, for example an EEPROM, battery-backed up RAM, Smart Card, memory stick, or the like, may be provided to store setup data and parameters as necessary. It is to be additionally understood that the memory devices may take the form of any type of readable media, such as, for example, ROM, RAM, SRAM, FLASH, EEPROM, Smart Card, memory stick, a chip, a hard disk, a magnetic disk, and/or an optical disk. Still further, it will be appreciated that some or all of the illustrated memory devices 202, 204, and 206 may be physically incorporated within the same IC chip as the microprocessor 200 (a so called “microcontroller”) and, as such, they are shown separately in FIG. 2 only for the sake of clarity.


To cause the controlling device 100 to perform an action, the controlling device 100 is adapted to be responsive to events, such as a sensed user interaction with the key matrix 216, receipt of a data or signal transmission, etc. In response to an event appropriate instructions within the memory may be executed. For example, when a command key is activated on the controlling device 100, the controlling device 100 may retrieve a command code corresponding to the activated command key from memory 204 or 206 and transmit the command code to a device in a format recognizable by the device. It will be appreciated that the instructions within the memory can be used not only to cause the transmission of command codes and/or data to the appliances but also to perform local operations. While not limiting, other local operations that may be performed by the controlling device 100 include execution of pre-programmed macro command sequences, displaying information/data, manipulating the appearance of a graphical user interface presented on a local LCD display 218, etc. For convenience and economy of development effort, the software programming of controlling device 100 may utilize an underlying operating system such as, for example, Microsoft's “Windows CE” or “Windows Mobile” brand operating systems.


As contemplated in the above referenced and related U.S. patent application Ser. Nos. 12/629,433, 11/357,681 and 11/218,900 and provisional applications 61/266,014, 60/201,021, 60/608,183 and 60/705,926, the graphical user interface (“GUI”) and certain functionalities of controlling device 100 may be defined as a set of interrelated pages for display on the touch screen of an exemplary controlling via the use of a software based editing tool 300, i.e., computer executable instructions stored on a physically embodied, non-transient memory device, which editing tool may be provided as in the form of an application program to be installed on a PC 302 running an operating system, for example, a Microsoft “Windows” brand operating system, as generally illustrated in FIGS. 3a and 3b and described in further detail hereinafter. In the illustrative examples that follow, it will be appreciated by those skilled in the art that development tools such as Microsoft's Visual Studio, the C# programming language, and various third party libraries may be used to facilitate creation of the software comprising exemplary editing tool 300 and exemplary controlling device 100 GUI and functionality.


Editor application 300 may be offered by the manufacturer of the controlling device 100 on a CD ROM, for download from a Web site, etc., as appropriate for installation on a PC of the user's choice. Once the editor application is installed on the user's PC 302, the controlling device GUI may be created or revised using the editor application, stored locally in device memory as a file 310 on PC 302 and/or caused to be downloaded into controlling device 100 via a hardwired connection 304, a wireless link 306 (e.g., WiFi, Bluetooth, Zigbee, etc.) or any other convenient means. Additionally, it will be appreciated that the editor application 300, although primarily resident on the user's local PC 302, may also be adapted to access additional data items from remotely located servers via the Internet 308, from appliances linked to the PC 302 via a home network, etc. Examples of such items may include, without limitation, IR command codes (e.g., to allow for support of new appliances), data which indicates operations supported by an appliance, device model number cross-references (e.g., for entering into the controlling device for set-up purposes as disclosed in, for example, U.S. Pat. No. 6,587,067), operational software updates for controlling device 100, etc. It will also be appreciated that in such an environment data may also be uploaded from PC 302 to a centralized repository, e.g., a remotely located, Internet accessible server. Such uploaded information may include, for example, current user configurations, learned IR code data, etc., and may be comprised of or derived from data stored locally on PC 302 (for example, file 310) and/or data retrieved from controlling device 100 during the times controlling device 100 is coupled to PC 302. It will also be appreciated that in alternative embodiments, all or part of the editor program itself may be resident on a Web server platform, for example in the form of ActiveX, JavaScript, etc. programming and as such the PC-based editor 300 is presented herein by way of example only, without limitation.


Certain aspects of the operation of exemplary controlling device 100 will now be discussed in conjunction with FIGS. 4 through 8. In this context, as will be appreciated by those familiar with the relevant art and/or with the previously referenced parent and U.S. provisional applications, the actual appearance and functionality of all the GUI pages in controlling device 100 represent only one instance of the output of editor application 300. It will thus be understood that the GUIs and associated functionality presented herein are by way of example only and not intended to be limiting in any way.


Controlling device 100 may include both a touch activated LCD screen 218 with soft keys (or other form of touch panel) and several groups of hard buttons 414, 416, 418, 420. The hard buttons groups might comprise, for example, a volume control group 416 (e.g., volume up, down, and mute), a channel changing group 418 (e.g., channel up, down, and return), a navigation group embodied in disk 414 (e.g., for menu navigation and selection including up, down, left, right, and enter/select), and/or a row of programmable keys 420 (e.g., keys for supporting macros or other to-be-configured functions).


Upon start of operation, or any time the “Home” button 422 (e.g., a button located on the side of the device) is activated, an exemplary Home Page GUI 400 may be presented within the display. The illustrated, exemplary home Page 400 includes five touch-activated buttons. By way of example only, touching icon 402 may be used to initiate the activity of watching cable TV by causing controlling device 100 to transmit the commands required to power on cable STB 104, power on TV 102, select the TV input to which the cable STB is connected, and then cause the controlling device GUI to transition to a page (e.g., display having soft keys, an EPG, or the like) from which cable STB channel selection may be input (for further tuning, retrieving related content information, etc.). Touching icon 404 may be used to similarly cause the controlling device to place the entertainment system into a condition suitable for an activity such as watching a DVD movie, while touching icon 406 may be used to cause the controlling device to place the system into a condition for an activity such as listening to music. Touching icon 408 may be used to cause the controlling device to transition to another page 500 of the GUI (an example of which is shown in FIG. 5) from which individual appliance control pages may be called up, i.e., navigated to, using icons 502 (e.g., to navigate to a page having cable STB related control icons), 504 (e.g., to navigate to a page having TV related control icons), 506 (e.g., to navigate to a page having DVD player related control icons), and 508 (e.g., to navigate to a page having audio receiver related control icons). Examples of individual appliance control pages are shown in FIG. 6 (GUI page 600 having soft keys for use in controlling receiver input selection commands), FIG. 7 (GUI page 700 having soft keys for use in controlling DVD transport functions), and FIG. 8 (GUI page 800 having soft keys for use in cable STB channel number entry).


In this way it will be understood and appreciated that a plurality of commands and/or actions may be performed both locally on controlling device 100 and remotely on the various appliances under the control of controlling device 100 in response to a single or multiple interaction(s) by a user with the key matrix 216 of controlling device 100.


Turning now to FIG. 9, the operation of an editing program 300 which may be used to create the above-disclosed, exemplary GUI pages and associated functionality will be described in further detail. For this purpose, the PC screen display of the editor application may be divided into several windows or panels, each having a specific purpose. By way of example, the panels may be as follows:


Main project panel 902, used to display the current GUI page being edited (Home Page 400 in this illustration) together with a representation 922, in this example, of the hard keys (keys 414 through 420) available on target controlling device 100;


Project View panel 904, used to display all currently defined GUI pages in a tree structure form (which may, as depicted in the exemplary embodiment shown, have collapse [−] and expand [+] functionality including selective expansion of individual nodes and/or a collapse all/expand all feature) where the GUI page to be edited may be selected (e.g., by clicking on a link) from within the tree structure list and wherein the GUI page being displayed in the Main project panel 902 may be indicated by a highlight 918 (the Home Page in the instant illustration);


Properties panel 906, used to display a list of (and allow editing of—for example by text entry, selection from drop down menus, etc.) the properties (such as the caption text and font attributes, symbol position, button type, etc.) associated with a presently selected GUI icon or hard key image within Main project panel 902 (GUI icon or soft key 404′ with label “DVD Movie” in this illustration, as indicated by the highlight (dotted line) around icon 404′ displayed in Main project panel 902);


Gallery panel 908, used to display graphic images which may be dragged and dropped onto the GUI pages being edited in window 902 wherein the Gallery choices may include sets of icons for use as buttons, page backgrounds, symbols for labeling buttons, key groups (to allow a group of related key icons, e.g. a numeric pad, to be dragged into place in a single operation), to allow pre-defined themes to be applied to single pages or groups of pages, or in an exemplary embodiment to allow home control interface items such as n-state widgets to be dragged and dropped onto GUI pages being edited, and wherein the Gallery in use (when multiple, organized Galleries are provided) is selected via tabs 914 according to the exemplary embodiment shown;


Actions panel 910, used to display a list of (and allow editing of—for example by dragging and dropping to change the order, by deleting selected items, etc.) the actions to be performed by controlling device 100 when the currently selected icon (in the Main panel 902) is activated by a user when the user interface is provided to the controlling device (e.g., in the example presented, it can be seen that activating the “DVD Movie” icon 404′ will: (1) transmit a “Power On” command to DVD player 106, (2) transmit a “Power On” command to TV set 102, (3) wait one second for the devices to stabilize, then (4) transmit a “Component 2” input selection command to TV 102, (5) transmit “DVD” input selection command to Audio Receiver 108, and finally (6) jump to GUI page 700 corresponding to the DVD transport controls (illustrated in FIG. 7); and


Devices panel 912 which is preferably used to display a listing of all remote control commands available for each of the appliances setup to be controlled by controlling device 100 wherein the list of commandable functions for a given appliance to be displayed may be selected from a drop down list 916 (which in the illustrative example would comprise a TV 102, a cable STB 104, a DVD player 106, an audio receiver 108, a security camera 112, and a lamp dimmer 114) and wherein the commandable functions so displayed may be assigned to any icon displayed in main project panel 902 by simply clicking and dragging a commandable function icon to, for example, a desired location with a listing of functions displayed in the Actions panel 910 and/or over an icon displayed in the Main panel (where it would be added, for example, to the top or bottom of the listing of commands within the Action panel display).


In certain embodiments, an exemplary editing program 300 may further support the configuration of reusable GUI elements which may incorporate all or some of information display, touch activatable control or input, data retrieval and/or manipulation, decision, issuance of commands to appliances, etc., such GUI elements hereafter referred to as “widgets.” Advantageously, the creation of such widgets by a user of editing program 300 may be facilitated by the provision of various programming blocks, each representing a specific function (hereafter “blocks”) which, in a widget definition mode of editor 300, may be dragged onto a graphic workspace and interconnected by mouse clicks in order to define the functionality of a widget. Illustrations of such a workspace and associated editing tools may be found in FIGS. 11a, 11b and 12. As illustrated, a listing of available functionalities may be presented in a blocks panel 1102 from which individual blocks may be dragged onto a work surface 1100,1200 and interconnected as necessary to define the series of steps and/or actions to be taken by a controlling device when executing a particular widget, for example a widget 1104 to display a security camera picture or a widget 1204 to adjust a lighting level.


Each programming block may be graphically represented as a processing unit with input and output ports. Data may be transferred from block to block via these ports, i.e., according to the connections made from one block's output to the input of another block during widget definition. Turning for the moment to FIG. 10, an exemplary group of such programming blocks may include, without limitation:


System Event 1002.


Inputs: None. Outputs: Trigger value. Properties: A system event may comprise, for example, controller wakeup, page load, WiFi on, WiFi off, etc. A system event Block may be triggered when the specified event occurs and its output used to trigger other Blocks.


Timer 1004:


Inputs: None. Outputs: Integer value. Properties: A timer Block may output a value after the specified delay, which output may be used to trigger other Blocks. Optionally, a timer Block may also be used to generate repetitive trigger outputs at a specified interval.


Button 1028:


Inputs: A trigger value. Outputs: ButtonUp or ButtonDown (e.g., integer values “0” or “1”). Properties: Displays an activatable touch screen button. Programmed parameters may include an image and/or text caption for display, X-Y coordinates for placement on the touch screen, etc.


Hard Button 1008:


Inputs: None Outputs: KeyUp or KeyDown (e.g., integer values “0” or “1”). Properties: Assigned to a physical hard key of the controlling device, for example by selection from a drop-down menu at programming time.


Slider 1026:


Inputs: Current position, minimum, maximum. Outputs: New position input by user.


Properties: Displays a slider bar on the controlling device touch screen and allows user input to adjust the current value.


Constant 1006:


Inputs: Any trigger. Outputs: The value specified at programming time. Properties: Outputs a fixed value when triggered.


Flag (Global or Local) 1010:


Inputs: Set value or get value. Outputs: Value established by the most recent set command. Properties: A global flag may be accessible from any programming in the controlling device, while a local flag may be accessed only from within the programming corresponding to the current page. Note: In the exemplary embodiment contemplated herein, as a general rule widget programming may not span pages, i.e., a widget is only active while the GUI page with which it has been associated is currently displayed by the controlling device. A global flag may thus be utilized for example to transfer a data value from a widget in one page to a widget in another page.


If/Then 1012:


Inputs: Integer. Outputs: True or false. Properties: Logical comparison of the input to a preset value, according to one of the following operators: Equals, Not Equals, Greater, Greater or equals, Less, Less or equals.


Math 1014:


Inputs: Two integer values. Output: Result value. Properties: Performs one of the following mathematical calculations: Add, Subtract, Multiply, Divide, Modulo.


Multiplexer 1016:


Inputs: One or more. Outputs: One. Properties: Performs a logical AND or OR function. When defined as AND, all inputs must be present to produce an output. When defined as OR, any present input will produce an output.


Repeater 1018:


Inputs: Integer value. Outputs: Successive triggers. Properties: The sequence of program blocks following this one will be repeated the number of times specified by the input value.


Switch 1020:


Inputs: One value. Outputs: One of many. Properties: Programmed with a list of values. When an input is received, this is compared to the programmed list and the output corresponding to the matching value is triggered.


Toggle/Stepper 1022:


Inputs: Trigger. Outputs: One of many. Properties: Each successive input cycles to the next output in sequence.


Action 1024:


Inputs: Trigger. Outputs: None. Properties: This block executes any action(s) that have been assigned to it, for example transmission of an appliance control command, macro, page switch, etc.


Image 1030:


Inputs: Any supported image file, for example .png, .bmp, .jpg, etc. Outputs: None. Properties: Displays an image on the touch screen, for example album art, camera image, etc. Programmed parameters may include X, Y coordinates and size.


Serial, Z-Wave or IP Device 1032, 1034:


Inputs: Command string or integer. Outputs: Response from addressed appliance. Properties: Causes transmission of the input data to the specified target appliance selected from devices panel 912. The transmission medium, e.g., WiFi, Zwave, serial I/O, etc., to be used may be determined by the nature of the target appliance selected.


Returning now to FIG. 11, a widget 1104 for displaying an image retrieved from security camera 112 may be created by dragging and connecting programming blocks as follows: Initiation of the widget may be defined by blocks 1106, 1108 and 1110. Whenever a page containing widget 1104 is loaded for display by controlling device 100 (resulting from inclusion of block 1106) and every three seconds thereafter for as long as that page continues to be active (resulting from the inclusion of block 1108) the logical “OR” function of block 1110 may issue a trigger 1112 to cause output of a predefined constant ACSII string by block 1114. This constant ASCII string may comprise an image retrieval command to be transmitted via WiFi link 120 to security camera 112 which has been associated with IP device block 1116. The output of IP device block 1116, that is the retrieved camera image (e.g., in the form of a JPEG file), is then passed to image display block 1118 for presentation on the screen of controlling device 100 with size and position as indicated. As will be appreciated, the individual options and parameters associated with each block may be defined for example via selection of item(s) from drop down menus and/or via use of data entry fields which may be initiated by double clicking each block or settable block parameter, for example as illustrated in the case of the establishing of the parameter for system event block 1106 by use of the drop down menu shown on page 1120 of FIG. 11b.


In this manner a widget may be defined which will automatically display a current security camera image whenever a controlling device page containing that widget is loaded. Turning now to FIG. 13, once an exemplary security camera display widget 1104 has been defined it may then be available for use as an object in controlling device GUI pages. For example, a “door camera” page 1302 may be created and an instance of security camera widget 1104 dragged onto page 1302. The size and location of the display area 1304 within page 1302 may be as defined within programming block 1118 of FIG. 11a. With reference to FIG. 14, once door camera page 1304 has been defined in this manner, a button 1402 may be created on device control page 500 and assigned an action 1404 which may comprise jumping to the newly-created door camera page 1304. When downloaded and executed by an exemplary controlling device 100 as illustrated in FIG. 15, the above described programming may enable a user (e.g., upon hearing a doorbell) to activate button 1402 and thereby cause retrieval and display 1304 of an image 1502 captured by security camera 112.


By way of further example, the programming of an exemplary lighting level control widget 1204 will now be discussed in conjunction with FIG. 12. Once again, initiation of widget 1204 may occur upon loading of a page containing that widget, as illustrated by programming block 1206. This may be used to trigger the issuance of a “get current level” command by block 1208, e.g., to a Z-wave light controller device such as 114 of FIG. 1. The resulting lighting level value may be passed to a progress/slider block 1210 to cause display of a slider bar at the designated touchscreen coordinates. If user touch input is received changing the position of the slider, the new value may comprise an output of block 1210 which in turn may become an input for a level setting command to be issued to device 114 by block 1212. If such a widget were assigned a GUI page 1306 and activation button 1406 in the manner previously described, download and execution by an exemplary controlling device 100 upon activation of button 1406 may result in a GUI display 1504 as illustrated in FIG. 15.


While various concepts have been described in detail, it will be appreciated by those skilled in the art that various modifications and alternatives to those concepts could be developed in light of the overall teachings of the disclosure. For example, while the embodiments presented above are described in the context of universal remote controls (i.e., controlling devices capable of commanding the operation of multiple classes of appliances devices from multiple manufacturers) as being most broadly representative of controlling devices in general, it will be appreciated that the teachings of this disclosure may be equally well applied to other controlling devices of narrower capability, and also to any general or specific purpose device requiring a visual interface (i.e., display screens, signage devices, teleprompters, etc.) without departing from the spirit and scope of the present invention. Still further, it will be appreciated that the user interfaces described herein need not be limited to controlling devices but can be utilized in connection with any device having input elements wherein it is desired to convey information concerning such input elements. For example, the user interface may be utilized with devices such as calculators, phones, appliances, etc. having input elements having associated information conveying images in the form of alphanumeric and/or symbolic labels. It will also be understood that modification, editing, or updating of configuration settings may be performed either by a user or though any automated computing processes as are well known in the art. As such, the particular concepts disclosed are meant to be illustrative only and not limiting as to the scope of the invention which is to be given the full breadth of the appended claims and any equivalents thereof.


All documents cited within this application for patent are hereby incorporated by reference in their entirety.

Claims
  • 1. A computer-readable media embodied on a physical, non-transient memory device having instructions for creating a user interface for provision to a hand-held device adapted to control functional operations of one or more appliances, the instructions performing steps comprising: receiving input to create a widget which is activatable via the user interface of the hand-held device to cause the hand-held device to perform at least one action, the widget comprising a plurality of pre-defined, user selected programming blocks each graphically represented as a processing unit with at least one of an input and an output of which user selected ones of the inputs and outputs of the pre-defined, user selected programming blocks are graphically interconnected via user interaction to define the at least one action to be performed upon activation of the widget; andreceiving input to add the created widget to a user interface to be provided to the hand-held device.
  • 2. The computer-readable media as recited in claim 1, wherein the input to create the widget further comprises input used to define one or parameters associated with one or more of the pre-defined, user selected programming blocks.
  • 3. The computer-readable media as recited in claim 1, wherein drag and drop operations are used to add the pre-defined, user selected programming blocks onto a graphic workspace.
  • 4. The computer-readable media as recited in claim 3, wherein mouse clicks are used to connect inputs and outputs of the pre-defined, user selected programming blocks added onto the graphic workspace.
  • 5. The computer-readable media as recited in claim 1, wherein the widget is associated with an icon and wherein the widget is activated in response to a user selection of the icon when displayed in a touch-screen display of the hand-held device.
  • 6. The computer-readable media as recited in claim 1, wherein the widget is associated with a page of the user interface and wherein the widget is activated in response to a user selection made to cause a display of the page in a touch-screen display of the hand-held device.
  • 7. The computer-readable media as recited in claim 1, wherein the widget is associated with a hard key of the hand-held device and wherein the widget is activated in response to a user selection of the hard key.
  • 8. The computer-readable media as recited in claim 1, wherein activation of the widget causes a retrieval of data from one or more appliances in communication with the hand-held device.
  • 9. The computer-readable media as recited in claim 8, wherein activation of the widget causes a display of the retrieved data in a display of the hand-held device.
  • 10. The computer-readable media as recited in claim 1, wherein activation of the widget causes a transmission of a control command to one or more appliances in communication with the hand-held device.
  • 11. The computer-readable media as recited in claim 1, wherein the pre-defined, user selected programming blocks are selected from a library of pre-defined programming blocks including one or more of a system event programming block, a timer programming block, a button programming block, a hard button programming block, a slider programming block, a constant programming block, a flag programming block, an if/then programming block, a math programming block, a multiplexer programming block, a repeater programming block, a switch programming block, a toggle programming block, an action programming block, an image programming block, and an appliance response receiving programming block.
  • 12. The computer-readable media as recited in claim 1, wherein the pre-defined, user selected programming block are selected from a library of pre-defined programming blocks including logic performing blocks and input and/or output performing blocks.
  • 13. A method for creating a user interface for provision to a hand-held device adapted to control functional operations of one or more appliances, comprising: creating at a development system a widget which is activatable via the user interface of the hand-held device to cause the hand-held device to perform at least one action, the created widget comprising a plurality of pre-defined, user selected programming blocks each graphically represented as a processing unit with at least one of an input and an output of which user selected ones of the inputs and outputs of the pre-defined, user selected programming blocks are graphically interconnected via user interaction to define the at least one action to be performed upon activation of the widget; adding the created widget to a user interface to be provided to the hand-held device; andcausing the user interface to be provided from the development system to the hand-held device.
  • 14. The method as recited in claim 13, wherein creating the widget further comprises defining one or parameters associated with one or more of the pre-defined, user selected programming blocks.
  • 15. The method as recited in claim 13, wherein creating the widget comprises using drag and drop operations to add the pre-defined, user selected programming blocks onto a graphic workspace of the development system.
  • 16. The method as recited in claim 15, wherein creating the widget comprises using mouse clicks to connect inputs and outputs of the pre-defined, user selected programming blocks added onto the graphic workspace.
  • 17. The method as recited in claim 13, comprising associating the widget with an icon whereby the widget will be activated in response to a user selection of the icon when displayed in a touch-screen display of the hand-held device.
  • 18. The method as recited in claim 13, comprising associating the widget with a page of the user interface whereby the widget will be activated in response to a user selection made to cause a display of the page in a touch-screen display of the hand-held device.
  • 19. The method as recited in claim 13, comprising associating the widget with a hard key of the hand-held device whereby the widget will be activated in response to a user selection of the hard key.
  • 20. The method as recited in claim 13, wherein activation of the created widget will cause a retrieval of data from one or more appliances in communication with the hand-held device.
  • 21. The method as recited in claim 20, wherein activation of the created widget will cause a display of the retrieved data in a display of the hand-held device.
  • 22. The method as recited in claim 13, wherein activation of the created widget will cause a transmission of a control command to one or more appliances in communication with the hand-held device.
  • 23. The method as recited in claim 13, wherein the pre-defined, user selected programming blocks are selected during the step of creating the widget from a library of pre-defined programming blocks including one or more of a system event programming block, a timer programming block, a button programming block, a hard button programming block, a slider programming block, a constant programming block, a flag programming block, an if/then programming block, a math programming block, a multiplexer programming block, a repeater programming block, a switch programming block, a toggle programming block, an action programming block, an image programming block, and an appliance response receiving programming block.
  • 24. The method as recited in claim 1, wherein the pre-defined, user selected programming block are selected during the step of creating the widget from a library of pre-defined programming blocks including logic performing blocks and input and/or output performing blocks.
RELATED APPLICATION INFORMATION

This application claims the benefit of U.S. Provisional Patent Application No. 61/266,014, filed on Dec. 2, 2009. This application also claims the benefit of and is a continuation-in-part of U.S. application Ser. No. 12/629,423, filed Jun. 24, 2009, which in turn is a continuation-in-part of U.S. application Ser. No. 11/357,681, filed Feb. 16, 2006, which in turn is a continuation-in-part of U.S. application Ser. No. 11/218,900 (now U.S. Pat. No. 7,266,777), filed on Sep. 2, 2005, which in turn claims the benefit of U.S. Provisional Patent Application Nos. 60/608,183, filed on Sep. 8, 2004, and 60/705,926, filed on Aug. 5, 2005.

Provisional Applications (3)
Number Date Country
61266014 Dec 2009 US
60608183 Sep 2004 US
60705926 Aug 2005 US
Continuation in Parts (3)
Number Date Country
Parent 12629423 Dec 2009 US
Child 12956154 US
Parent 11357681 Feb 2006 US
Child 12629423 US
Parent 11218900 Sep 2005 US
Child 11357681 US