Introduction

icon

13

pages

icon

English

icon

Documents

Écrit par

Publié par

Le téléchargement nécessite un accès à la bibliothèque YouScribe Tout savoir sur nos offres

icon

13

pages

icon

English

icon

Documents

Le téléchargement nécessite un accès à la bibliothèque YouScribe Tout savoir sur nos offres

[TUTORIAL: HOW TO CREATE AN HTML TEMPLATE WITH THE
May 5, 2008 WEBCLIENT LIBRARY]

Introduction
This tutorial is meant as an introduction to creating HTML/CSS templates based on
the Webclient JavaScript library which can be used via the Trace Universal Control
Hub (UCH) to interact with connected target devices such as televisions and
satellite boxes through an online DHTML interface (graphic or text).
For the purpose of this tutorial, you need to have downloaded two other projects
from Trace: The Universal Control Hub for Java (UCHj), and the SatelliteBox
simulation. The SatelliteBox simulation is an applet simulating a SATELLITE BOX that
can be controlled from the UCH. A target adapter for the SATELLITE BOX is
included in the UCH package. Target adapters for other devices (including real
devices) may be developed on top of the UCH reference implementation, but this is
not in the scope of this tutorial.
Server and Device Connection
This tutorial assumes that you have successfully installed the UCH and SatelliteBox
packages provided by Trace. Please read accompanying readme files for details
how to do this. Limited instructions have been provided here:
In order to control a fake device via the UCH server using your new interface, you
need to do some initial setup work.
First, install Tomcat and copy UCH.war into your web applications directory. For
more information on installing Tomcat, check out
(http://www.devx.com/webdev/Article/16416). ...
Voir icon arrow

Publié par

Nombre de lectures

107

Langue

English

 
[ TUTORIAL: HOW TO CRAETE AN HTML TEMPLA TWEITH THE May 5, 2008 WEBCLIENT LIBRAR ] Y
Introduction This tutorial is meant as an introduction to creating HTML/CSS templabtea s  ed on the Webclient JavaScript librarywhich can be used via the Trace Universal Control Hub (UCH) to interact with connected target devices such as televisions and satellite boxes through an onlineD HTMLi nterface (graphic or text.) For the purpose of this tutorialy, ou need to have downloaded two other projects from Trace: The Universal Control Hub for Java (UCHj , )  and the SatelliteBox simulation .  The SatelliteBox simulation aisn  applet simulating a SATELLITE B OtXhat can be controlled from the UCH. A target adapter for the SATELLITE BOX is included in the UCH package. Target adapters for other devices (including real devices) may be developed on top of the UCH reference implementation, but this is not in the scope of this tutori.a l
Server and Device Connection This tutorial assumes that you have successfully inlestda lthe UCH and SatelliteBox packages provided by Trace. Please read accompanying readme files for details how to do this. Limited instructions have been provided here: In order to control a fake device via theUCH server using your new interface, you need to do some initial setup work. First, install Tomcat and copyU CH.war into your web applications directory. For more information on installing Tomcat, check out (http://www.devx.com/webdev/Article/16416).  Once Tomcat is installed and theUCH application has been unpacked and is running, simply run the fakSeATELLITE BOdXevice. The fake device and the Tomcat server do not necessarily have to be on the same computer, but they should be on the same local network (with no firewall between them). After running the fake device and the Tomcat server together, your web client interface should automatically connect to the UCH server and allow you to control the fake target device.
 
f a d, oume Vol.nT tuotcenoehs Doe umolttbu” wnttub ”pUV a ,noup of buttons co.oT ehf ritsg oran” and Of  bf”sisno stna fnO rguoer e hhtw tianelol pontr a cgol ecarT eht dn as,onttbuf  opss erswoh ehTugifregu:  1Fi lenn”pU dna hC neanDol ” wnttbuno.s 
Design This tutorial is not meant to be  daesign tutorial, but Ive included the tsep here to illustrate the fact that visual design ranging from simple to advanced interfaces can be used to create fully functioning internet remote controls for media devices. The design shown below is the one I will be using throughout this tutoriaol.u gT h this design is not the simplest possible, it is also not the most complex. It allows for a reasonable display of the capacities of the Webc lient libraryoperating through an HTML/JavaScript webpage. The following design will utilize thsea tellite boxs functions which control the satellite box’s power , channel , and volume  setting .s The available functions of a target device are to be specified by its developer/manufacturer in a “socket description. ” The appendix shows the complete socket description of the satellite bo.x 
 
[ TUTORIAL: HOW TO CRAETE AN HTML TEMPLA TWEITH THE May 5, 2008 WEBCLIENT LIBRAR ] Y
 
g inndpoesrrcoh n tnereffid a otnel,chanred umbeCaha  sewlla  sMa e , ond anehT iht ttub”.no3x4 arrard is a otsne ca yfob tu
[ TUTORIAL: HOW TO CRAETE AN HTML TEMPLA TWEITH THE May 5, 2008 WEBCLIENT LIBRAR ] Y
 Accessibility It is important to keep users with disabilities in mind when designing an interface. You may want to consider creating multiple versions of the same interface to acco mmodate for users with poor eyseight, among other things. One of the nice things about the URC framework is that user interfaces can be easily exchanged (that’s why we also call them “pluggable user interfaces”).   For example, here is a high contrast version of the above desni gmade for people with poor eyesight:
 
 Figure 2:The figure shows a control panel with three groups of buttons, and the Trace logo. The buttons are the saams ei n figure 1, but are rendered in black and white only, including the log.o
[ TUTORIAL: HOW TO CRAETE AN HTML TEMPLA TWEITH THE May 5, 2008 WEBCLIENT LIBRAR ] Y  
Implementation <head> Create a new .html file and open it for modification in whichever .html editor you prefer. Various JavaScript files which interact with the backend sockeatnd namespace definitions will be made available to you. The <head> area of your .html page must link to these files as follows:
 
HEAD          < TITLE >S AMPLE C ONTROLLER </ TITLE >         < META HTT -PEQUIV ="C ONTENT -T YPE " CONTENT =" TEXT / HTML ; CHARSET =ISO-8859-1"/>         < LINK REL =" STYLESHEE "  THREF ="S ATELLIT B EOX . CSS " TYPE =" TEX / TCSS "  />           < SCRIPT LANGUAGE = J " AVASCRIPT " TYPE =" TEX / TJAVASCRIPT "  SRC ="ORG MYURC WEBCLIENT. JS "> _ _  </ SCRIPT >         < SCRIPTLANGUAGE = J " AVASCRIPT " TYPE =" TEXT / JAVASCR IPT "  SRC =" ORG . MYURC . SOCKET . JS  ">  </ SCRIPT >         < SCRIPT LANGUAGE =" JAVASCRIPT " TYPE =" TEX / TJAVASCRIPT "  SRC =" ORG . MYURC . SCHEM A . JS ">  </ SCRIPT      >        < SCRIPT LANGUAGE =" JAVASCRIPT " TYPE =" TEXT / JAVASCRI PT "  _ _ SRC =" ORG MYURC URCHTTP . JS ">        </ SCRIPT > _ _         < SCRIPT LANGUAGE = J " AVASCRIPT " TYPE =" TEX / TJAVASCRIPT " SRC =" ORG MYURC LIB . JS ">  </ SCRIPT > </ HEAD >
 The link  > tag here connects to a CSS file which handles the layout of visual < elements. You can look at the CSS file if you wish, but sitcreation will not be included in this tutorial. The <script  > tags which follow provide the page with the functions it needs to interact with the TraceUCH and your socket-enabled interactive device.
 
 
[ TUTORIAL: HOW TO CRAETE AN HTML TEMPLA TWEITH THE May 5, 2008 WEBCLIENT LIBRAR ] Y In order for the web remote inetrface to function properly the following JavaScript commands must also be included in the <head>  area of the document:
<scri t lan ua e=" avascri t t e="text/ avascri " // List of sockets that the client wants to receive udpates from (i.e. open sessions with).sockets = [ "http://res.myurc.org/upnp/demo/satelliteBox/socket" ]; updateInterval = 2000; // Poll for updates every 2 seconds.   function init() {             try {org_myurc_webclient_init(sockets,updateInterval); }             catch (ex) { alert(typeof ex === "string" ? ex : ex.message); }          }                   function finalize() {             org_myurc_webclient_finalize();          } </script>   These JavaScript functions will be called when the .html page loads and unloads. The sockets  variable defines, for the UCH,which sockets will be in use by the interface (this is needed for receiving updates from the UCH).The updateInterval specifies the polling rate for events from the UCH 2 . 0  00 means it polls for updates every 2  000 ms, i.e. every 2  seconds. With that, short of any changes to the CSS for design purposes, all necessary changes to the .html file’s <  head> section have been made.  <body> In order for the interface to function properly the <  body> tag itself must appear like the following: <bod onLoad="init()" onUnload="finalize This tag calls the encessary JavaScript functions that we just defined in the <head> section of the page.  
   
 
[ TUTORIAL: HOW TO CRAETE AN HTML TEMPLA TWEITH THE May 5, 2008 WEBCLIENT LIBRAR ] Y
At this point you should write your CSS and get the visual display functioning properly with regular HTML and CSS code. DO NOT change any of the code from the <head> or <body> sections that you wrote in earlier steps of this tutorial. You design should now appear as you like in your chosen web browser.
Interactive Elements This design uses images to simulate the appearance of buttons. You can look at the CSS if you do ’nt know how this was done and are interested in simulating the effect. In order to pass data to the interactive device being used you need to employ the  onclick  event handler of the images you are using as buttons. Th o e n  click  event handler calls the setValue  function from org_myurc_webclient.js  which was imported in the <head> section of the page.  Note: To make our interface keyboard-accessible, we also need to define an onkeypress event handler with the same content as the onclick event handler. Here isan example which sets the p  owerMode value to ON :
<im src="im/ ower on off " . onclick="org_myurc_webclient_setValue('http://res.myurc.org/upnp/demo/sa telliteBox/socket#/powerMode', 'ON')"  onkeypress="or_gmyurc_webclient_setValue('http://res.myurc.org/upnp/dem o/satelliteBox/socket#/powerMode', 'ON'") tabindex="1" alt="power o /n>" 
  org_my _ ent_setValue function requires two parameters: urc webcli 1.  A socketPath to the value you wish to update. You’ll notice that the first part (the socket name) is what we used in thesockets variable in the header code and the remainder (after the ‘#’ sign)is the path to the value to be updated. The satellite box makesthe followingvariable paths available to be updated with the included values or value like them, with the exception of / previousChannel, which is a read-only field: a.  / powerMode i.  ON ii.  STANDBY b.  / activeChannel
 
   
 
[ TUTORIAL: HOW TO CRAETE AN HTML TEMPLA TWEITH THE May 5, 2008 WEBCLIENT LIBRAR ] Y i.  Any integer between 1 and 12 c.  / previousChannel (read-only) i.  Any integer between 1 and 12 d.  / volume i.  Any integer between 0 and 100 e.  /mute i.  true ii.  false 2.  The value you wish to use from the one s tlei d above. The available values for activeChannel / previousChannel  will likely change depending on the data being used, but this general outline will still apply. You may have noticed that this framework doesn’t directly allow for incrementing the volume,as the buttons would suggest. In order to accomplish that you need to have the button call aJavaScript function that you’ve written which reads in the current value of v  olume , increments it, and then stores the new value in volume . Such a function may look like the following:
function volumeInc() {  var curVol = parseInt(org_myurc_webclient_getValue('http://res.myur.corg/upnp/demo/satelliteBox/socket #/volume'));  curVol + 5; =  org_myurc_webclient_setValue('http://res.myurc.org/upnp/demo/satelilteBox/socket# /volume', curVol)  }  Reactive Elements In addition to having an interface capable of sending messages to a given device through the UCH socket definitions, you can create an interface which reacts to the current state of that device. For example, through JavaScript you can create an interface which highlights the button corresponding to the current active channel. You can also highlight the mute button if the device is currently muted. These examples are among the least complicated; the UCH system,through JavaScript implementation, allows for far-ranging and creative interfaces which react dynamically to the state of your device.
Voir icon more
Alternate Text