Professional Documents
Culture Documents
ivan.bernal@epn.edu.ec
http://ginga.epn.edu.ec
Ginga -NCL
Ivn Bernal, Ph.D.
Ivan.bernal@epn.edu.ec
http://ginga.epn.edu.ec
Agenda
Generalidades
TV digital
Interactividad
STB
Ginga (middleware)
Ginga-NCL
Ginga-J
Conectores
Ejemplo
Bibliografa
1.
Generalidades
Ginga es el nombre que recibe el middleware.
Ginga permite ejecutar aplicaciones interactivas dentro de un STB
(Set-Top Box).
En el mercado existen STBs de distintos fabricantes y puede variar la
plataforma de hardware/software de los mismos.
Necesidad clara de tener un middleware que permita correr aplicaciones sin
importar que STB se tenga.
Los STBs tendrn la capacidad de actualizar su firmware as como tambin
la versin de Ginga.
Se puede actualizar por aire: mtodo de actualizacin masivo, y es el broadcaster de TV
quien se encarga de emitir la actualizacin.
A travs de un dispositivo USB: el fabricante provee un pendrive o bajando la
actualizacin desde la web.
Noviembre 2012/ Draft
Generalidades
Ginga
Middleware abierto.
Se subdivide en dos subsistemas interrelacionados que permiten el
desarrollo de aplicaciones siguiendo dos paradigmas de programacin
diferentes.
Ginga-J (para aplicaciones procedimentales Java)
Ginga-NCL (para aplicaciones declarativas NCL)
Generalidades
NCL (Nested Context Language)
NCL is an XML application language based on the NCM (Nested Context Model)
NCM is a conceptual model for hypermedia document specification, with temporal and
spatial synchronization among its media objects.
Generalidades
NCL (Nested Context Language)
Las aplicaciones se pueden ejecutar de dos maneras en el STB.
Las aplicaciones a ejecutar en los STBs vienen dentro de la seal que reciben,
en un canal de datos dedicado para las aplicaciones.
Este canal, recibe el nombre de carrusel de datos, dado que se va
iterando sobre los datos de manera circular envindolos constantemente.
Esto es necesario porque cuando se sintoniza un canal de televisin, el
STB debe poder descargar el contenido completo del carrusel.
Luego ya sea por voluntad del usuario, o por eventos emitidos desde el
brodcaster la aplicacin se ejecuta.
La aplicacin es cargada a travs de un dispositivo USB y ejecutada.
Descargar del Internet por el canal de retorno
Puede venir embebida en el STB.
Generalidades
NCL (Nested Context Language)
Lenguaje declarativo
Significa que los programas declaran el resultado esperado.
Quien ejecuta el programa debe articular los recursos necesarios para
obtener lo que se declara.
Para comprender esta idea, considerar el lenguaje declarativo HTML,
donde se declara una pgina web pero no se indica paso a paso como
obtenerla, sino que el navegador web interpreta esta declaracin y la
muestra con sus propios algoritmos en base a los recursos que maneja.
10
Generalidades
NCL (Nested Context Language)
El lenguaje declarativo NCL puede adems complementarse con el lenguaje
de scripting Lua, combinando programacin declarativa+procedural.
Salvando la diferencia entre lenguajes y el uso especfico para aplicaciones
de TV interactiva de Ginga-NCL-Lua.
Este enfoque es anlogo al uso del lenguaje declarativo HTML con el de scripting
Javascript que se aplica en el desarrollo de paginas web.
11
Generalidades
The basic NCL structure module defines:
Te root element, called <ncl>, and its children elements:
The <head> element
The <body> element
12
Generalidades
The <head> element may have the following elements as its
children:
<importedDocumentBase>
<ruleBase>
<transitionBase>
<regionBase>
<descriptorBase>
<connectorBase>
<meta> and <metadata>
13
Generalidades
The <body> element may have the following elements as
its children:
<port>
<property>
<media>
<context>
<switch>
<link>
14
Eclipse
15
Eclipse
16
Eclipse
17
Eclipse
18
Eclipse
19
20
NCL
Todos los nombres de las etiquetas (tags) estn en letras
minsculas.
A diferencia de HTML, en donde <HTML>, <html>, <Html> y
<hTMl> todas se refieren a la misma cosa.
En NCL, los nombres de las etiquetas son sensibles a
maysculas y minsculas.
Todos los nombres de las etiquetas NCL usan minsculas y as se las debe
utilizar.
21
NCL
Elementos
Toma una de dos formas.
Start tag y end tag (etiquetas de inicio y fin) cuyos tipos deben coincidir.
22
NCL
Planificar!!!!!!
23
Ejemplo
Dentro de <head>:
Definir una <region> dentro de <regionBase>
Una regin define el espacio de exhibicin de un objeto medio
24
Ejemplo
region id="rgScreen"
width=100%
height=100%
left=top= 0%
region id="rgBoton"
left="3%
top="5%"
height="10%"
width="10%"
25
Ejemplo
region id="rgBanner"
top=0%"
left="70%"
height="100%"
width="30%"
region id="rgInferior"
top="75%"
left="0%"
height="25%"
width="70%"
Noviembre 2012/ Draft
26
Ejemplo
27
Ejemplo
28
Ejemplo
Los documentos hipermedios estn compuestos generalmente por
nodos (ns) y enlaces (links, elos).
Cada nodo representa un medio y cada enlace representa la relacin entre
medios.
Una relacin entre medios puede especificar, por ejemplo, que en un
determinado momento de la presentacin de un medio, otro debe iniciarse.
29
Ejemplo
Ejemplo: considerando un programa audiovisual interactivo que
al iniciar la presentacin de un video, inicie tambin la
presentacin de una imagen y texto.
30
Ejemplo
NCM (Nested Context Model) Modelo de Contextos anidados
Para estructurar/organziar de mejor manera la seccin body (que es un contexto global),
pueden emplearse los contextos para enmarcar algunos medios que estn estrechamente
relacionados. Por ejemplo: los tems de un men.
31
Ejemplo
MiConector (onBeginStart)
Apenas existe un rol de condicin y un rol de activacin.
onBegin: condicin que indica que el enlace se activa cuando el nodo asociado a este rol es
iniciado.
start : accin indicando que el enlace, al ser activado, inicia una presentacin del nodo asociado
a este rol.
El conector inicia la presentacin del nodo ligado al rol start cuando el nodo asociado al rol
onBegin es presentado
32
Ejemplo
33
Ejemplo
En NCL 3.0 solo hay un tipo de conector : causal connector.
Define condiciones sobre las cuales el enlace puede ser activado y las acciones que sern
realizadas cuando el enlace sea activado.
Un conector causal debe poseer por lo menos una condicin y una accin.
Cada condicin o accin est asociada a un rol, punto de interfaz del conector que participar
de las asociaciones (bind) del enlace.
Se lee: cuando la condicin, entonces la accin
Cuando <algn nodo> inicia, termina <algn nodo>
34
Ejemplo
Noviembre 2012/ Draft
35
Ejemplo
<causalConnector id=MiConector">
<simpleCondition role="onBegin" />
<simpleAction role="start" />
</causalConnector>
Noviembre 2012/ Draft
36
Ejemplo
<link xconnector="MiConector">
<bind role="onBegin" component="video"/>
<bind role="start" component="info"/>
</link>
37
Ejemplo
</connectorBase>
38
Ejemplo
<link xconnector="CONN#onKeySelectionStartNStopN">
<bind role="onSelection" component="info">
<bindParam name="keyCode" value="BLUE"/>
</bind>
<bind role="stop" component="info"/>
<bind role="start" component="lista"/>
<bind role="start" component="inferior"/>
</link>
Noviembre 2012/ Draft
39