[0001] The invention relates to a method for generating a user interface on a HAVi device
for the control of a Non-HAVi device. This invention in particular applies to the
field of domestic communication networks. The invention also concerns a gateway for
use in the method for generating a user interface as well as two types of computer
programme products.
Background
[0002] A few years ago the typical home audio/video equipment setup was characterized by
a mix of CE devices of different types, e.g. a radio receiver, a CD player, a pair
of speakers, a television set, a video cassette recorder, a tape deck, a DVD player,
a satellite receiver and the like. For interaction of the devices point-to-point connection
of analogue/digital input/outputs had to be made. For this purpose various kinds of
different wires were available like Scart cables, Cinch cables, Coax cables, optical
fibre, and so forth.
[0003] Meanwhile there are strong activities in the consumer electronics field to avoid
this type of point-to-point connections. A number of standards for home networks already
exist that can be used to connect all the different components to each other via a
single type of network cable. In the consumer electronics field first of all the IEEE1394
bus standard should be mentioned here. The IEEE1394 bus system provides for a high
data rate communication between the CE devices. The cable version supports data rates
of 100, 200 and 400 Mbit/s. This is enough to transport asynchronous data for controlling
a network station as well as isochronous audio and video streams in parallel. Isochronous
and asynchronous data transfer modes are supported. However, the IEEE1394 standard
specifies only the lower layers of the ISO/OSI reference model, namely the physical
layer, the data link layer and the transaction layer. Therefore, the higher layers
namely transport layer, session layer, presentation layer and application layer are
left open for proprietary definition.
[0004] A consortium of consumer electronics companies worked on a standard for the audio/video
electronics and the multimedia industry wherein the higher communication layers have
been specified. This standard is referred to as the HAVi standard, where HAVi stands
for Home Audio/Video interoperability. This standard primarily has defined an interoperability
middleware that ensures that products of different vendors can interoperate, i.e.
cooperate to perform application tasks. The application layer remains completely open
to proprietary solutions.
[0005] Another consortium of companies, in particular computer companies including Microsoft,
started another initiative for setting up a network control software stack based on
Internet Protocols (IP). This network system is called UPnP (Universal Plug and Play)
network. This system shall be open to all kinds of electronic components that could
be integrated in a network in particular personal computers, but also electronic appliances
in a household like refrigerators, microwave ovens, heating control, air conditioning
control, security systems, washing machines and the like. The UPnP network system
supports controlling of all these appliances via the Internet, therefore, even if
somebody is on a journey, he can manage to monitor and control his home appliances.
[0006] Even though HAVi and UPnP have sometimes been seen as competitors, and in some ways
they are, they serve somewhat different markets and have somewhat different goals.
It is therefore foreseen a scenario that both networks exist in parallel in a household
and that bridging is possible between the two for data exchange and interaction between
UPnP network components and HAVi network components. This however calls for the creation
of the bridging technology between HAVi and UPnP networks.
[0007] When talking of a bridge between UPnP and HAVi networks this technically means that
a data packet is transferred to the other side on the data link layer. When transferring
a data packet on a higher layer of the ISO/OSI reference model the bridging device
is then called a gateway. As the data packets are transferred from HAVi to UPnP network
or vice versa on a higher layer, the bridging device will be called gateway hereinafter.
This is not meant limiting however.
[0008] With the gateway in between both networks, it shall be possible to control a HAVi
device in the HAVi network from a UPnP device in the UPnP network. Also it shall be
supported to control a UPnP device from a HAVi device.
[0009] For the controlling of the HAVi device from a UPnP device it is required to represent
the HAVi devices as a UPnP device. Here, specific problems need to be solved that
are not part of the present invention.
[0010] The invention deals with the problem of controlling a UPnP device from a HAVi device.
To understand the invention it is advantageous to first explain the architecture of
the HAVi system. According to the HAVi architecture a CE device in the network is
controlled through abstract representations of the CE device. The architecture allows
a module (e.g. device representation, controller, etc.) to send commands or control
information to another module in the home network. A HAVi-compliant device contains
data (above abstract representation referred to as device control module DCM) relating
to its user interface and to its control capabilities. This data includes for example
HAVi byte code (Java code) that can be uploaded and executed by other devices on the
network. A HAVi-compliant device has, as a minimum, enough functionality to communicate
with other devices in the HAVi network. During interaction, devices may exchange control
data and application data in a peer-to-peer fashion. The HAVi specification distinguishes
between controllers and controlled devices. A controller is a device that acts as
a host for a controlled device. A controller hosts the abstract representation for
the controlled devices.
[0011] The HAVi specification defines HAVi compliant CE devices in the following categories:
Full-AV devices (FAVs), Intermediate-AV devices (IAVs) and Base-AV devices (BAVs).
[0012] An FAV contains a complete set of software components of the HAVi software architecture.
An FAV is characterized in that it has a run-time environment for HAVi byte code.
This means it has a JAVA virtual machine. This enables an FAV device to download JAVA
byte code form other devices, e.g. for providing enhanced capability for their control.
An FAV may be formed by e.g. a HAVi compliant set top box, a HAVi compliant digital
TV receiver or a home personal computer. For example an intelligent TV receiver can
be the HAVi controller of other devices connected to the network. The receiver gets
the byte code uploaded from another device in the network. An icon representing this
device can be made to appear on the TV screen and user interaction with the icon may
cause elements of the control programme to actuate the represented device in a pre-specified
manner.
[0013] An IAV does not provide a run-time environment for HAVi byte code but may provide
native support for control of specific devices on the home network. An IAV comprises
embedded software elements that provide an interface for controlling general functions
of the specific devices. These software elements need not be HAVi byte code and may
be implemented as native applications on the IAV that use native interfaces to access
other devices.
[0014] A BAV may provide uploadable HAVi byte code but does not host any of the software
elements of the HAVi architecture. A BAV is controllable through an FAV by means of
the former uploaded byte code. A BAV is controllable through an IAV via its DCM/FCM
that has been uploaded by an FAV. Communication between an FAV or an IAV on the one
hand and a BAV on the other hand requires that the HAVi byte code is instantiated
by an FAV.
[0015] The HAVi specification includes a number of main software elements that are listed
below. For a more detailed explanation of these elements it is referred to the HAVi
specification. An existing version of the HAVi specification is V1.1, published May
15, 2001 and available from HAVi, INC., 2694 Bishop Drive, Suite 275 San Ramon, CA
94683, USA.
1. The 1394 communications media manager (CMM) acts as an interface between the other
software elements and IEEE1394 bus.
2. An event manager (EM) informs the various software elements of events in the network
such as the changes in the network configuration that occur when appliances (devices)
are added or removed from the network.
3. A registry - maintains information about the appliances connected to the network
and the functions they offer.
Applications can obtain this information from the registry.
4. A messaging system (MS) - serves as an API (Application Programming Interface)
that facilitates communication between the software elements of the various appliances
on the network. The messaging system provides the HAVi software elements with communication
facilities. It is independent of the network and the transport layers. The messaging
system is in charge of allocating identifiers for the abstract representations at
the FAV or IAV.
These identifiers are first used by the abstract representations to register at the
FAV or IAV. Then they are used by the abstract representations to identify each other
within the home network. When a first abstract representation wants to send a message
to another abstract representation it has to use the identifier of the latter while
invoking the messaging API.
5. A device control module (DCM) - represents an appliance on the network. An application
program can interact directly with a DCM. Within a DCM a number of functional control
modules (FCM) may be contained. In a HAVi network, a functionality is represented
by an FCM. Hierarchically speaking an FCM is always contained in a DCM, representing
a device. A DCM may contain more than one FCM (e.g. a DCM representing a digital VCR
contains a Tuner FCM and a VCR FCM) but there is only one DCM for each HAVi device.
6. A DCM manager - installs the DCMs. It automatically reacts to changes in the network
by installing new DCMs for new BAV appliances.
7. A data driven interaction (DDI) controller - renders GUI (Graphical User Interface)
on an appliance display on behalf of a HAVi software element. It supports a wide range
of displays varying from graphical to text only.
8. A stream manager (SMGR) - creates connections and routes real time AV streams between
two or more appliances on the network.
[0016] Basic HAVi interoperability addresses the general need to allow existing devices
to communicate at a basic level of functionality. To achieve this, HAVi defines and
uses a generic set of control messages that enable one device to communicate with
another device and a set of event messages that it should reasonably expect from a
device given its class (TV, VCR, DVD player, etc). To support this approach a basic
set of mechanism is required: Device discovery; Communication; and a HAVi message
set. As to device discovery: Each device in the home network needs a well-defined
method that allows it to advertise its capabilities to others. The HAVi approach is
to utilize so-called SDD data: Self Describing Data. The SDD data is required on all
HAVi devices in the network. SDD data contains information about the device, which
can be accessed by other devices. The SDD data contains as a minimum enough information
to allow instantiation of a so-called embedded device control module (embedded DCM).
An embedded DCM is a piece of code preinstalled on a controlling IAV or FAV in a platform
dependent code and using native interfaces to access the IAVs for FAVs resources.
As mentioned above, a DCM for a device is a software element that provides an interface
for control of general functions of the device. Instantiation of an embedded DCM results
in registration of the devices capabilities with a registry. The registry provides
a directory service and enables an object on the network to locate another object
on the network. Registering allows applications to infer the basic set of command
messages that can be sent a specific device on the network.
[0017] As to communication: Once an application has determined the capabilities of a device
the application needs to be able to access those capabilities. This requires a general
communication facility allowing applications to issue requests to devices. The service
is provided by the HAVi messaging systems and DCMs. The application sends HAVi messages
to DCMs, the DCM then engage in proprietary communication with the devices.
[0018] As to HAVI message sets: In order to support basic interoperability a well defined
set of messages is required that must be supported by all devices of a particular
known class (e.g. the class of TV receivers, the class of VCRs, the class of DVD players
etc.). This ensures that a device can work with existing devices, as well as with
future devices, irrespective of the manufacturer. These three basic requirements support
a certain minimal level of interoperability. Since any device can query the capabilities
of another device via the registry, any device can determine the message set supported
by another device. Since applications have access to the messaging system, any device
can interact with any other device.
[0019] Basic HAVi interoperability ensures that devices can interoperate at a basic level
of functionality. However, a more extended mechanism is needed to also allow a device
to communicate to other devices with any additional functionality that is not present
in the embedded DCMs on an FAV. For example, embedded DCMs may not support all features
of existing products and are unlikely to support those totally new ones of future
product categories.
[0020] HAVi 'Level 2' interoperability provides this mechanism. To achieve this the HAVi
architecture allows uploadable DCMs as an alternative to so called embedded device
control modules. An uploadable DCM may be provided by any suitable source, but a likely
technique is to place the uploadable DCM in the HAVI SDD data on the BAV device and
upload from the BAV to the FAV device when the BAV is connected to the home network.
Because the HAVi architecture is vendor-neutral it is necessary that the uploaded
DCM will work on a variety of FAV devices all with potentially different hardware
architectures. To achieve this, uploaded DCMs are implemented in HAVi (JAVA) byte
code. The Java byte code run-time environment on FAV devices supports the instantiation
and execution of uploaded DCMs. Once created and running within an FAV device the
DCM communicates with the BAV devices in the same manner as described above.
[0021] Under the new scenario, where a HAVi network is connected with a UPnP network via
a gateway, and a UPnP device shall be controlled by a HAVi FAV device, the additional
problem occurs that none of the UPnP devices provides a HAVi DCM that could be uploaded
to the HAVI FAV device. Therefore, neither basic nor level 2 interoperability is available
for the controlling of UPnP devices from a HAVi network station.
Invention
[0022] It is an object of the invention to solve the problem of controlling a Non-HAVi compliant
device in a Non-HAVi network from a HAVi compliant FAV device in a HAVi network via
a gateway. For some of the UPnP devices there could exist in the gateway device a
corresponding representation in the form of a DCM with an embedded device specific
FCM. This DCM/FCM could be used for generating a user interface on the HAVi FAV device
for controlling the UPnP device using basic interoperability. The user could, therefore,
generate control commands for the UPnP device that need to be interpreted in the gateway
and transformed into a corresponding UPnP command that would be understood in the
UPnP device to be controlled.
[0023] A problem is however that there are certainly UPnP devices existing for which no
corresponding representation in the form of a FCM, exist in the HAVi system. For such
a case there is the possibility implemented in the HAVi system to generate a so-called
generic FCM. In case of an unknown UPnP device, the gateway can only provide a DCM
having embedded a generic FCM for the control of the UPnP device. With this generic
FCM the HAVi FAV device cannot generate a user interface because none of the functions
of the UPnP device are known in the generic FCM. This is the crux of the problem underlying
the invention.
[0024] The invention solves the problem with the means of the independent claims 1, 8, 12
and 15. The invention utilizes the possibility in the HAVi system to download from
a DCM a so-called HAVLET that is executable JAVA byte code to generate a user interface
on the HAVi controller. This HAVLET software piece interacts with the DCM for the
Non-HAVi devices stored and executed in the gateway. The Non-Havi DCM contains a specialized
Non-HAVi FCM that includes the software routines for requesting the function descriptions
of a Non-HAVi device and for forwarding them to the HAVI FAV device. The HAVLET running
on the HAVi FAV device takes the function descriptions of the Non-HAVi device and
generates a corresponding user interface with these function descriptions.
[0025] Advantageous, modifications and improvements of the invention are listed in the dependent
claims. Very advantageous is, if the FCM running on the gateway comprises means for
translating the function descriptions read from the Non-HAVi device (23) into a data
form supported by the HAVi system before forwarding to the HAVi controller. This improvement
simplifies the HAVLET software running on the HAVi controller very much. The means
for translating the function description of the Non-HAVi device need not be included
in the HAVLET, thus making it unnecessary to upload a corresponding software code
into the HAVi FAV device, thereby reducing memory requirements in the HAVI FAV device.
Likewise the processor of the HAVi FAV device is relieved.
[0026] The invention can best be utilized if a HAVi network needs to be combined with an
IP-based network, e.g. the UPnP network. In case of a UPnP network a UPnP device is
represented by means of so-called XML descriptions for each function of a UPnP device.
The XML descriptions will be requested by the specialised function control module
which is of the type generic FCM (according to the HAVi specification) running on
the gateway, translated and then be forwarded to the HAVLET executed by the HAVi controller.
For each translated function description the HAVLET will generate a graphical representation
preferably in the form of a button, slider, query button or input field together with
a symbol or expression that explains the meaning.
[0027] A gateway according to the invention is claimed in independent claim 8.
[0028] Independent claim 12 claims a computer programme product, namely a function control
module FCM for the gateway according to the invention.
[0029] Independent claim 15 claims a computer programme product, in particular HAVLET, running
on the HAVi controller according to the invention.
Drawings
[0030] Exemplary embodiments of the invention are illustrated in the drawings and are explained
in more detail in the following description.
[0031] In the figures:
- Fig. 1
- shows an example of a HAVi network and a UPnP network connected to each other via
a gateway;
- Fig. 2
- shows the basic software elements interacting to each other of the UPnP device, the
gateway and the HAVi controller;
- Fig. 3
- shows an example of a user interface for the control of a UPnP security camera displayed
on the HAVi controller;
- Fig. 4
- shows a programme listing for a function control module for the use in the gateway
according to the invention;
- Fig. 5
- shows a programme listing for a HAVLET to be executed by a HAVi controller according
to the invention; and
- Fig. 6
- shows a programme listing for a service description routine that will be called when
executing the function control modul.
Exemplar embodiments of the invention
[0032] Fig. 1 depicts the principle structure of two networks being connected to each other
via a gateway 10. On the left side of the figure it is shown a UPnP network. As an
example reference number 21 denotes a washing machine, reference number 22 a refrigerator,
reference number 23 a security camera, reference 24 a heating control unit, and reference
25 a personal computer having an ISDN/DSL Internet connection. All these UPnP devices
are connected to an Ethernet data bus 20 for data exchange. The Ethernet bus lines
are also connected with gateway 10. On the right side of figure 1 is shown a HAVi
network. The reference number 31 marks a TV set, reference number 32 denotes a VCR,
reference number 33 denotes a DVD player and reference number 34 stands for a set
top box such as a digital satellite receiver. The HAVi network stations are connected
to an IEEE1394 bus 30 for data exchange. The gateway 10 is also connected to the 1394
bus 30. The gateway 10 comprises an IP protocol stack 11, on one side, a HAVi protocol
stack 12 on the other side as well as software for carrying out the translation or
mapping of control messages and events from one network to the other.
[0033] The HAVi as well as the UPnP specifications are known in the art. Therefore, there
is no need to explain all the details in these specifications for the purpose of disclosing
the present invention. It is therefore expressively referred to the HAVi specification
as well as the UPnP specification for this purpose. The UPnP specification can be
obtained from the UPnP Forum managed by Microsoft Incorporation.
[0034] As mentioned before the UPnP network system is based on the existing Internet protocols.
A graphical user interface (GUI) for controlling UPnP devices from an UPnP controller,
e.g. the personal computer 25 may consist of a plurality of icons displayed on the
computer monitor. When a user selects an icon, the HTML pages are retrieved from of
the device in question. The HTML pages are displayed for the user. This allows the
user to control the given device. In the UPnP specification it is defined that each
UPnP device comprises a list of services, which are provided by the device. Each of
these services is described in an XML document, where XML stands for Extension Mark-up
Language, i.e. Internet technology. Each XML document contains a detailed description
of all control possibilities within the service. These XML documents will be utilized
for controlling a UPnP device from a HAVi controller.
[0035] The control process of the UPnP device from a HAVi FAV device is illustrated in Fig.
2. Identical reference numbers denote the same components as shown in Fig. 1 and need
not be explained again. In Fig. 2 the Ethernet interface circuit 26 with which UPnP
devices as well as the gateway are equipped are separately shown. Similarly the 1394
bus interface 35 for the HAVi network components and the gateway 10 are likewise shown.
In addition the basic software elements of the security camera 23, the gateway 10
and the TV set 31 are shown in Fig. 2. A security camera 23 contains an XML document
in which the control possibilities for the security camera are listed. The important
software element of the gateway is a device control module DCM containing a specified
function control module FCM as well as an executable JAVA programme HAVLET. The JAVA
programme HAVLET is provided for an upload to a HAVi FAV device during the configuration
phase of the HAVi network. Therefore, the very important software element of the HAVi
controller 31 concerns this HAVLET.
[0036] For controlling the security camera 23 the gateway interacts with the security camera
23 and the TV set 31 as follows.
[0037] After finishing of the configuration phase in both networks, all the network components
within the HAVi network as well as in the UPnP network can be controlled from the
TV set 31. A user interface for controlling these devices is built in the form of
a list of icons for each controllable device. It is the communications media manager
CMM, the event manager EM, the registry and the messaging system MS of the HAVi protocol
stack, that are utilized for collecting the information of all controllable elements
be it in the HAVi network or in the UPnP networks. Of course, the gateway 10 includes
corresponding software elements and interfaces so that the mapping of the UPnP devices
in the HAVi registry is possible. This process however is pre-supposed to be prior
art and will not be explained in further detail here.
[0038] A user may now wish to control the security camera from the TV set 31 in the HAVi
network. For this purpose he selects the corresponding icon on the TV screen. This
event will start the download of the HAVLET into the internal memory of the TV set
31. Right after the download, the execution of the HAVLET is started. The HAVLET is
an executable JAVA programme. As JAVA is a platform independent programming language,
it will run on each HAVi FAV device that has a run-time environment for JAVA byte
code.
[0039] Third, the executed HAVLET sends a request for retrieving information about the security
camera 23 to the gateway 10. This request will be accepted by the running UPnP function
control module FCM that itself retrieves the XML document/s stored on the webserver
of the security camera 23. Each XML document contains descriptions of the control
possibilities for the security camera 23. The FCM translates the XML descriptions
into a struct (a set of variables) and forwards them to the HAVLET running in the
TV set 31. The HAVLET then takes these function descriptions and generates for each
controllable element a graphical representation such as button, slider, query button,
input field or the like to generate the graphical user interface for the control of
the security camera on the TV screen. The flow of information is illustrated in Fig.
2 with arrows and the numbering expresses the order of interaction.
[0040] The graphical user interface for the security camera 23 is shown in Fig. 3. For each
controllable element of the security camera a graphical representation is generated,
e.g. for the brightness setting a slider is shown on the TV screen. With a mouse pointer
the brightness can directly be controlled by means of the left/right buttons positioned
at the left and right side of the slider. Also the slider itself could be dragged
to the wanted position as known from a great variety of computer menus. At the left
side of the slider for the brightness adjustment the expression Set-Brightness is
shown in writing. This expression is directly taken over from the XML description
for this controllable element. The FCM running in the gateway does not necessarily
know the meaning of this expression. This is evident if one considers that a new type
of product can be integrated in the UPnP network for which today nobody knows what
the controllable elements are. In such a case the user has to make the right interpretation
of this controllable element by himself. Below the brightness slider a GetBrightness
button is positioned. This is an example of a query button. By depressing this query
button the current brightness set value will be read out and displayed beside the
button. Below the GetBrightness button are positioned simple buttons IncreaseBrightness
and DecreaseBrightness. These buttons have the same effect as the right and left buttons
of the SetBrightness slider. An example of an input field is the field SetDefaultRotation.
Here a number is requested with this field and shall be entered into the input mask.
The input parameter determines the rotation of the security camera for getting another
view. Instead of displaying the extracted expression for the respective control element
derived from the XML description, a self-explanatory symbol could be displayed in
the user interface. This however calls for the need to have pre-defined user interface
components installed in the HAVLET for the different services of the various possible
UPnP devices. Even if a new type of appliance will be integrated in the UPnP network,
the pre-defined user interface component could be used if this new device provides
a service for which the user interface components are already provided in the HAVLET.
For unknown services however, this solution would not work. Another solution is that
there will be a mix of both different solutions for one service. For all the parameters
in the XML description to which already a symbol had been assigned, a corresponding
symbol could be displayed in the user interface. For the unknown parameters however,
the corresponding expressions need to be shown.
[0041] The XML document of a UPnP device can be regarded as a standard implementation of
the UPnP specification. For the realization of the present invention no extraordinary
programming has to be made here. The basic software elements for realization of the
present invention are the UPnP FCM running on the gateway and the HAVLET uploaded
into the HAVi FAV device. Both software elements include extraordinary routines for
the realization of the invention.
[0042] Fig. 4 shows the programme listing of the function control module for the UPnP network.
It is somehow a 'generic' FCM that will always be used for the control of any UPnP
device. The programming language is JAVA. This is a well-known programming language
widely used so that the particular syntax need not be explained here. The important
routines for implementing the invention are labelled. With label ? the routine for
extracting the services from the XML document is marked. This routine therefore extracts
which kind of service the requested UPnP device offers. For example the UPnP security
camera offers the service of providing a stream of video pictures in a particular
format like JPEG or Image at a certain compression level and resolution.
[0043] The GET_SERVICE_DESCRIPTION routine marked with label ?requests the information how
many services the UPnP device offers.
With the GET_SERVICE_INFORMATION_LIST routine marked with label ? the information
about every control possibility of the selected service can be retrieved. The routine
PERFORM_CONTROL_COMMAND is provided for sending a control command to a UPnP device,
see label ?. The routine PERFORM_DEVICE_VARIABLE_QUERY is provided for retrieving
the current variable value from a UPnP device, see label ?. These routines will be
executed upon a request from the HAVLET that runs on the HAVi device.
[0044] For the routine call corresponding instructions are hold in the second part of the
programme listing headed methods for answering the incoming request. Expressively
it is referred to the routine call DO_GET_SERVICE_DESCRIPTION marked with label ?,
and DO_GET_SERVICE_INFORMATION_LIST marked with label ?. A further important routine
for the implementation of the invention is the routine sendControlCommand for sending
a control command to the UPnP device. This routine is marked with label ?. Within
this routine a response message is also evaluated and forwarded to the HAVLET in the
HAVi device. Also important for the implementation of the invention is the routine
queryDeviceVariable marked with label ?. This routine is started if the HAVLET has
sent a corresponding request. For example if the user has pressed a query button,
this routine will be called. Again in this routine a response message will be sent
back to the HAVi device. With the routine receiveHttpNotifyData marked with label
? UPnP events will be handled.
[0045] The JAVA source code of a HAVLET implementing the invention is shown in Fig. 5. The
main task of the HAVLET is to build the user interface for controlling a UPnP device.
The complete routine for building the UI is labelled ?. The HAVLET contains corresponding
routines for getting the service descriptions for a UPnP device marked with label
?, for getting the service information list marked with label ?, for performing a
control command marked with label ? and for performing a device variable query marked
with label ?.
[0046] The function control module is integrated in a device control module according to
the HAVi specification. Therefore what needs to be done is to programme a device control
module having embedded the function control module of Fig. 4. This programme is regarded
to be a standard implementation of the HAVi specification that needs not to be explained
in detail. That is why the listing of the DCM is not being shown.
[0047] The part of the programme that performs the translation of the XML descriptions into
a data form supported by the HAVi system, is included in a routine called service
description routine, shown in Fig. 6. The XML descriptions are basically in text format.
These XML descriptions are evaluated. For example the programme part marked with label
? evaluates whether the XML descriptions contain some actions. These actions correspond
to the controllable elements of the UPnP device. They are translated into the HAVi-typical
form of a variable set called 'struct'. This is performed by parsing the XML description
and storing all information of interest in its local instance variables.
1. Method for generating a user interface on a HAVi device for the control of a Non-HAVi
device, where HAVi stands for Home Audio/Video interoperability, the HAVi device (31)
being a station of a HAVi network and the Non-HAVi device (23) being a station of
a Non-HAVi network, both networks being connected to each other by a gateway (10),
characterized in that the gateway (10) runs a function control module (FCM) for the Non-HAVi devices that
requests the descriptions of the functions of the Non-HAVi device (23) to be controlled
and forwards them to the HAVi device (31) that generates the corresponding user interface
components for the functions of the Non-HAVi device (23) by means of a JAVA programme
(HAVLET) that runs on the HAVi device (31).
2. Method according to claim 1, wherein the function control module (FCM) translates
the function descriptions read from the Non-HAVi device (23) into a data form supported
by the HAVi system before forwarding to the HAVi device (31).
3. Method according to claim 1, wherein the JAVA programme (HAVLET) translates the function
descriptions read from the Non-HAVi device (23) into a data form supported by the
HAVi system.
4. Method according to one of claims 1 to 3, wherein the gateway (10) uploads the JAVA
programme (HAVLET) to the HAVi device (31) during configuration.
5. Method according to one of the previous claims, wherein the HAVi device (31) on which
the user interface for controlling the Non-HAVi device (23) is generated is a HAVi
device of the FAV type, wherein FAV means Full Audio/Video HAVi device.
6. Method according to one of the previous claims, wherein the Non-HAVi network is an
IP based network, in particular a UPnP network, where UPnP stands for the Universal
Plug and Play network system.
7. Method according to claim 6, wherein the function descriptions of the Non-HAVi device
(23) are XML descriptions, where XML stands for Extension Mark-up Language.
8. Gateway for use in a method according to one of the previous claims, comprising an
interface (35) for a HAVi network and comprising an interface (26) for a Non-HAVi
network, characterized in that the gateway (10) comprises a function control module (FCM) that includes means for
requesting the function descriptions of the Non-HAVi device (23) and means for forwarding
the function descriptions to the network station of the HAVi network on which a user
interface for controlling a Non-HAVi (23) device shall be generated.
9. Gateway according to claim 8, comprising a JAVA programme (HAVLET) that includes means
for generating a user interface with the function descriptions of a Non-HAVi device
(23), this JAVA programme (HAVLET) being provided for an upload into a HAVi device
(31).
10. Gateway according to claim 8 or 9, wherein the function control module (FCM) comprises
means for translating the function descriptions read from the Non-HAVi device (23)
into a data form supported by the HAVi system before forwarding to the HAVi network.
11. Gateway according to claim 9, wherein the JAVA programme (HAVLET) comprises means
for translating the function descriptions read from the Non-HAVi device (23) into
a data form supported by the HAVi system
12. Computer programme product, in particular function control module (FCM) directly loadable
into the internal memory of a gateway (10) according to one of the claims 8 to 11,
comprising means for requesting function descriptions of a Non-HAVi device (23) and
means for forwarding the function descriptions to a network station of a HAVi network
on which a user interface for controlling the Non-HAVi device (23) shall be generated
when said product is executed by a processor of the gateway (10).
13. Computer programme product according to claim 12, further comprising means for translating
the function descriptions read from the Non-HAVi device (23) into a data form supported
by the HAVi system before forwarding to the HAVi network.
14. Computer programme product according to claim 12 or 13, wherein the function descriptions
of the Non-HAVI device (23) are XML descriptions, where XML stands for Extension Mark-up
Language.
15. Computer programme product, in particular JAVA programme (HAVLET), directly loadable
into the internal memory of a HAVi device (31) of a HAVi network, comprising means
for generating a user interface for the control of a Non-HAVi device (23) with the
function descriptions retrieved from the Non-HAVi device (23), when said product is
executed by a processor of said HAVi device (31).
16. Computer programme product according to claim 15, wherein the retrieved function descriptions
are translated XML descriptions of the Non-HAVi device (23), where XML stands for
Extension Mark-up Language and the XML descriptions being translated into a data form
supported by the HAVi system.
17. Computer programme product according to claim 15, further comprising means for translating
the function descriptions retrieved from the Non-HAVi device (23) into a data form
that is supported by the HAVi system and the function descriptions are XML descriptions,
where XML stand for Extension Mark-up Language.
18. Computer programme product according to one of claims 15 to 17, wherein the means
for generating a user interface comprise means for assigning to a translated function
description the appropriate graphical representation together with a symbol or expression
that explains the meaning of the function description.
19. Computer programme product according to claim 18, wherein the graphical representation
is in the form of a button, slider, query button or input field.