Documentos de Académico
Documentos de Profesional
Documentos de Cultura
CreaTVDigital Informe
CreaTVDigital Informe
Introduccin
Fig. 2. Modelo Conceptual NCM bsico junto con los elementos del lenguaje NCL.
Aplicaciones de TV Digital
Las aplicaciones en la televisin digital pueden ser aquellas que no tienen relacin
con el programa que se est transmitiendo (ej.: la muestra del estado del clima en un
programa de cocina), aplicaciones que tengan relacin con el programa en
transmisin (ej.: formacin de los equipos durante la transmisin de un partido de
ftbol) o pueden haber aplicaciones que necesiten de la interaccin del usuario como
por ejemplo un pequeo juego, preguntas y respuestas sobre el contenido de un
programa educativo, etc.
El sistema de TV Digital utiliza un middleware que permite ejecutar estas
aplicaciones interactivas dentro de un STB. Ese middleware es conocido como Ginga.
Ginga (Middleware Abierto del Sistema Brasilero de TV Digital - SBTVD) nos
permite correr aplicaciones sin importar qu STB tengamos actuando como una capa
que se aade a los patrones de referencia de un sistema de TV digital.
El middleware abierto Ginga se subdivide en dos subsistemas principales
interrelacionados que permiten el desarrollo de aplicaciones siguiendo dos
paradigmas de programacin diferentes. Dependiendo de las funcionalidades
requeridas en cada proyecto de aplicacin, un paradigma ser ms adecuado que otro.
Estos dos subsistemas se llaman Ginga-J (para aplicaciones procedurales Java) y
Ginga-NCL (para aplicaciones declarativas NCL e imperativas Lua) de los cuales
mencionaremos el segundo.
3.1
Quin comienza?
Qu mostramos?
Cundo mostramos el media?
Lua
Ginga, adems del lenguaje declarativo NCL, admite el lenguaje imperativo Lua.
El lenguaje es usado normalmente para permitir que una aplicacin sea extendida o
adaptada a travs de scripts. Lua es un lenguaje de fcil aprendizaje, que combina
sintaxis procedural con declarativa, con pocos comandos primitivos. Por lo tanto,
comparado con otros lenguajes, posee implementacin ligera y extensible. Otra de las
caractersticas es que posee un Garbage-collection, un sistema dinmico de tipos y un
alto grado de portabilidad, pudiendo ser ejecutada en diversas plataformas, tales como
computadores personales, celulares, consolas de video juego, etc.
3.4
NCL y Lua
Para poder integrar el lenguaje Lua al ambiente de la TV Digital y NCL, Lua fue
extendido con nuevas funcionalidades. Como por ejemplo, un elemento NCLua
precisa comunicarse con un documento NCL para saber cuando su objeto <media> es
iniciado por un link.
Aqu nombraremos las funcionalidades que agrega la biblioteca NCLua a Lua:
event, canvas, settings, persistent.
Para llamar a una aplicacin Lua desde NCL, se manipula al elemento Lua como
cualquier otro objeto media:
<body>
<media id="id" src="file.lua" descriptor="idD"/>
<body>
Para graficar las aplicaciones NCL se utilizan grficos espaciales (para representar
las regiones donde se mostrarn los objetos), grficos temporales (para representar el
tiempo de vida de un objeto) y grficos estructurales (para representar la acciones
ejecutadas por las ocurrencia de un evento).
Detalle
Media
Puertas (Ports)
Switch
Ejemplo tomado del libro: Soares, Luis Fernando Gomez y Simone Diniz, Junqueira
Barbarosa. Promamdo em NCL: Desemvolvimento de Aplicaes para middleware Ginga,
TV Digital e WEB. Rio de Janeiro : Elsevier, 2009
Analizando las figuras de los dos modelos podemos ver que es ms sencillo e
intuitivo representar una aplicacin mediante el modelo creado, vemos que es ms
fcil ubicarnos en el tiempo y realizar relaciones entre los medias.
En la figura 4 vemos al media animation como puerta de entrada, a partir del
cual al transcurrir el tiempo inician otros medias. El media icon posee la interaccin
indicando que al presionar el botn rojo del control remoto se iniciar el media
shoes.
El media shoes est representado con una Lnea de tiempo de media con
variabilidad de inicio segn momento de interaccin. La lnea punteada nos indica la
longitud del tiempo de la interactividad. Esto es para indicar que la aparicin y
finalizacin del media puede variar en ese intervalo de tiempo. Para mayor claridad
presentamos un ejemplo:
long i
Mayor fin
posible del media
Menor inicio
posible del media
B
(long i) / 2
(long i) / 2
CreaTV Digital
Estructura de la herramienta
rea Espacial
rea Temporal
Fig. 5. Secciones principales de la herramienta
Referencias
Apndice A:
Ejemplo de generacin de una aplicacin de TVD
interactiva usando "CreaTV Digital".
1
Apndice A:
Ejemplo de generacin de una aplicacin de TVD interactiva usando "CreaTV Digital".
II
Una vez asignados los medias a las regiones, en la seccin de rea temporal,
arrastraremos 04.mpg a la seccin de dibujo de lneas de tiempo, a continuacin
arrastraremos el media bonton.png de manera que coincida el inicio del video
principal con el de la imagen. Luego, con la herramienta de creacin de interactividad
abarcaremos todo el media y seleccionaremos el botn azul.
Fig. 10. Seccin rea temporal mostrando el control remoto para la seleccin de un botn
Apndice A:
Ejemplo de generacin de una aplicacin de TVD interactiva usando "CreaTV Digital".
III
Nos quedara arrastrar el media, que ser presentado como miniatura, hacia el
botn azul y asignarle al final de la vida de tiempo del media botn.png la accin de
detener al media dido.png.
Apndice A:
Ejemplo de generacin de una aplicacin de TVD interactiva usando "CreaTV Digital".
IV
Fig. 12. Aplicacin NCL corriendo bajo Ginga donde se muestra el video principal y el botn
Apndice A:
Ejemplo de generacin de una aplicacin de TVD interactiva usando "CreaTV Digital".
V
</connectorBase>
</head>
Apndice A:
Ejemplo de generacin de una aplicacin de TVD interactiva usando "CreaTV Digital".
VI
24.
<body >
25.
<port id="Port-04.mpg" component="04.mpg"/>
26.
<media id="04.mpg" src="../04.mpg"
type="video/mpeg" descriptor="descriptor-04.mpg">
27.
</media>
28.
<media id="dido.mpeg" src="../dido.mpeg"
type="video/mpeg" descriptor="descriptor-dido.mpeg">
29.
</media>
30.
<media id="boton.png" src="../boton.png"
descriptor="descriptor-boton.png">
31.
<area id="area1" begin="0s" end="42.8s"/>
32.
</media>
33.
<link id="Lboton.png"
xconnector="conEx#onKeySelectionStart">
34.
<bind role="onSelection" component="boton.png"
interface="area1">
35.
<bindParam name="keyCode" value="BLUE"/>
36.
</bind>
37.
<bind role="start" component="dido.mpeg">
38.
</bind>
39.
</link>
40.
<link id="LonBeginboton.png"
xconnector="conEx#onBeginStart">
41.
<bind role="onBegin" component="04.mpg">
42.
</bind>
43.
<bind role="start" component="boton.png">
44.
</bind>
45.
</link>
46.
<link id="LStopdido.mpeg"
xconnector="conEx#onEndStop">
47.
<bind role="onEnd" component="boton.png">
48.
</bind>
49.
<bind role="stop" component="dido.mpeg">
50.
</bind>
51.
</link>
52.
</body>
53. </ncl>