QML Hello World Tutorial/es: Difference between revisions

From Qt Wiki
Jump to navigation Jump to search
No edit summary
 
m (AutoSpider moved page QMLHelloWorldTutorial Spanish to QML Hello World Tutorial/es: Localisation)
 
(4 intermediate revisions by 2 users not shown)
Line 1: Line 1:
=Tutorial “Hola Mundo” con <span class="caps">QML</span>=
{{Cleanup | reason=Auto-imported from ExpressionEngine.}}


Este tutorial provee una introducción a <span class="caps">QML</span>, el lenguage de marcado de Qt Quick. Este tutorial no cubre todo; sólo hace énfasis en enseñar principios clave, las funciones se presentan tan pronto sea necesario.
[[Category:Spanish]]


A través de los distintos pasos de este tutorial aprenderemos acerca de los tipos básicos de <span class="caps">QML</span>, crearemos nuestros propios componentes <span class="caps">QML</span> con propiedades y signals, y crearemos una animación simpmle con la ayuda de estados y transicionnes.
= Tutorial "Hola Mundo" con QML =


El capítulo uno comienza con un programa mínimo de “Hola mundo” y en los siguientes capítulos presentaremos nuevos conceptos.
Este tutorial provee una introducción a QML, el lenguage de marcado de Qt Quick. Este tutorial no cubre todo; sólo hace énfasis en enseñar principios clave, las funciones se presentan tan pronto sea necesario.
 
A través de los distintos pasos de este tutorial aprenderemos acerca de los tipos básicos de QML, crearemos nuestros propios componentes QML con propiedades y signals, y crearemos una animación simpmle con la ayuda de estados y transicionnes.
 
El capítulo uno comienza con un programa mínimo de "Hola mundo" y en los siguientes capítulos presentaremos nuevos conceptos.


El código fuente del tutorial está ubicado en el directorio $QTDIR/examples/declarative/tutorials/helloworld.
El código fuente del tutorial está ubicado en el directorio $QTDIR/examples/declarative/tutorials/helloworld.


Capítulos del tutorial:
Capítulos del tutorial:
# Tipos Básicos
# Tipos Básicos
# Componentes <span class="caps">QML</span>
# Componentes QML
# Estados y Transiciones
# Estados y Transiciones


==Tipos Básicos==
== Tipos Básicos ==
 
El primer programa con QML es un simple "Hola mundo" que introduce algunos conceptos básicos de QML. La imagen de abajo muestra una captura de pantalla de este programa.
 
[[Image:http://doc.qt.nokia.com/4.7/images/declarative-tutorial1.png|http://doc.qt.nokia.com/4.7/images/declarative-tutorial1.png]]
 
El código QML para esta aplicación es el siguiente:


El primer programa con <span class="caps">QML</span> es un simple “Hola mundo” que introduce algunos conceptos básicos de <span class="caps">QML</span>. La imagen de abajo muestra una captura de pantalla de este programa.
<code> import Qt 4.7


[[Image:declarative-tutorial1.png]]
Rectangle {
id: page
width: 500; height: 200
color: "lightgray"


El código <span class="caps">QML</span> para esta aplicación es el siguiente:
Text {
id: helloText
text: "Hello world!"
y: 30
anchors.horizontalCenter: page.horizontalCenter
font.pointSize: 24; font.bold: true
}
}</code>


===Revisión línea a línea===
=== Revisión línea a línea ===


===Importar===
=== Importar ===


Primero importamos los tipos necesarios para este ejemplo. Muchos archivos <span class="caps">QML</span> importarán los tipos básicos de <span class="caps">QML</span> (como [http://doc.qt.nokia.com/4.7/qml-rectangle.html Rectangle] ''[doc.qt.nokia.com]'' o [http://doc.qt.nokia.com/4.7/qml-image.html Image] ''[doc.qt.nokia.com]'') utilizando:
Primero importamos los tipos necesarios para este ejemplo. Muchos archivos QML importarán los tipos básicos de QML (como [http://doc.qt.nokia.com/4.7/qml-rectangle.html Rectangle] o [http://doc.qt.nokia.com/4.7/qml-image.html Image]) utilizando:


===Elemento Rectangle===
<code>import Qt 4.7<code>


Declaramos nuestro elemento raíz el cuál será de tipo [http://doc.qt.nokia.com/4.7/qml-rectangle.html Rectangle] ''[doc.qt.nokia.com]'' (Rectángulo), uno de los tipos básicos de <span class="caps">QML</span>. Le asignamos un id con el cuál podremos referirnos a él posteriormente, en este caso le llamaremos page (página). También establecemos sus propiedades de ancho, alto y color mediante las palabras clave width, height y color.<br /> El elemento [http://doc.qt.nokia.com/4.7/qml-rectangle.html Rectangle] ''[doc.qt.nokia.com]'' tiene muchas otras propiedades (como posición en X y en Y) pero por ahora dejaremos que conserven sus valores por defecto.
=== Elemento Rectangle ===


===Elemento Text===
</code>
Rectangle {
id: page
width: 500; height: 200
color: "lightgray"<code>


Definimos un elemento tipo [http://doc.qt.nokia.com/4.7/qml-text.html Text] ''[doc.qt.nokia.com]'' (Texto), el cuál será hijo del elemento Rectangle raiz y que mostrará el texto “Hello world!” La propiedad Y es utilizada para posicionar el texto de manera vertical a 30 pixeles por debajo de la parte superior de su padre.<br /> Las propiedades font.pointSize (Tamaño de fuente) y font.bold (Negritas) están relacionadas con el tipo Font y es por ello que usan una notación con puntos (Tipo.propiedad).<br /> La propiedad anchors.horizontalCenter (anclas.CentroHorizontal) se refiere al centro horizontal de un elemento. En este caso, especificamos que nuestro elemento helloText debe estar centrado horizontalmente en el elemento page. Consulte [http://doc.qt.nokia.com/4.7/qml-anchor-layout.html#anchor-layout Anchor-based Layout] ''[doc.qt.nokia.com]'' (Organización basada en anclas)<br /> Las propiedades font.pointSize y font.bold properties están realacionadas con la fuente y utilizan la [http://doc.qt.nokia.com/4.7/qdeclarativeintroduction.html#dot-properties notación de punto] ''[doc.qt.nokia.com]''.
Declaramos nuestro elemento raíz el cuál será de tipo [http://doc.qt.nokia.com/4.7/qml-rectangle.html Rectangle] (Rectángulo), uno de los tipos básicos de QML. Le asignamos un id con el cuál podremos referirnos a él posteriormente, en este caso le llamaremos page (página). También establecemos sus propiedades de ancho, alto y color mediante las palabras clave width, height y color.
El elemento [http://doc.qt.nokia.com/4.7/qml-rectangle.html Rectangle] tiene muchas otras propiedades (como posición en X y en Y) pero por ahora dejaremos que conserven sus valores por defecto.


===Viendo el ejemplo===
=== Elemento Text ===


Para ver el ejemplo, ejecuta la herramienta [http://doc.qt.nokia.com/4.7/qmlviewer.html(localizada <span class="caps">QML</span> Viewer] ''[doc.qt.nokia.com]'' en el directorio bin) con el nombre del archivo como primer argumento. Por ejemplo, para ejecutar el ejemplo desde la localización de la instalación, debes escribir:
Definimos un elemento tipo [http://doc.qt.nokia.com/4.7/qml-text.html Text] (Texto), el cuál será hijo del elemento Rectangle raiz y que mostrará el texto "Hello world!" La propiedad Y es utilizada para posicionar el texto de manera vertical a 30 pixeles por debajo de la parte superior de su padre.
Las propiedades font.pointSize (Tamaño de fuente) y font.bold (Negritas) están relacionadas con el tipo Font y es por ello que usan una notación con puntos (Tipo.propiedad).
La propiedad anchors.horizontalCenter (anclas.CentroHorizontal) se refiere al centro horizontal de un elemento. En este caso, especificamos que nuestro elemento helloText debe estar centrado horizontalmente en el elemento page. Consulte [http://doc.qt.nokia.com/4.7/qml-anchor-layout.html#anchor-layout Anchor-based Layout] (Organización basada en anclas)
Las propiedades font.pointSize y font.bold properties están realacionadas con la fuente y utilizan la [http://doc.qt.nokia.com/4.7/qdeclarativeintroduction.html#dot-properties notación de punto].


==Componentes <span class="caps">QML</span>==
=== Viendo el ejemplo ===
 
Para ver el ejemplo, ejecuta la herramienta [http://doc.qt.nokia.com/4.7/qmlviewer.html(localizada QML Viewer] en el directorio bin) con el nombre del archivo como primer argumento. Por ejemplo, para ejecutar el ejemplo desde la localización de la instalación, debes escribir:
 
</code>bin/qml $QTDIR/examples/declarative/tutorials/helloworld/tutorial.qml</code>
 
== Componentes QML ==


Ahora agregaremos un selector de color a nuestra aplicación que servirá para cambiar el color de nuestro texto. La aplicación de esta sección del ejemplo se verá como en la siguiente imagen.
Ahora agregaremos un selector de color a nuestra aplicación que servirá para cambiar el color de nuestro texto. La aplicación de esta sección del ejemplo se verá como en la siguiente imagen.


[[Image:declarative-tutorial2.png]]
[[Image:http://doc.qt.nokia.com/4.7/images/declarative-tutorial2.png|http://doc.qt.nokia.com/4.7/images/declarative-tutorial2.png]]


El selector de color está hecho de seis celdas de distintos colores. Para evitar escribir el código varias veces, primero creamos un nuevo componente llamaco Cell (Celda/Casilla). Los componentes proveen maneras de definir un nuevo tipo que puede ser reutilizado en otros archivos <span class="caps">QML</span>. Un componente de <span class="caps">QML</span> es como una caja negra que interactua con el mundo exterior a través de propiedades, señales y slots y que generalmente está definido en su propio archivo <span class="caps">QML</span> (Para más detalles puedes ver Defining new Components (Definiendo nuevos componentes))<br /> El nombre del componente siempre debe comenzar con una letra mayúscula.
El selector de color está hecho de seis celdas de distintos colores. Para evitar escribir el código varias veces, primero creamos un nuevo componente llamaco Cell (Celda/Casilla). Los componentes proveen maneras de definir un nuevo tipo que puede ser reutilizado en otros archivos QML. Un componente de QML es como una caja negra que interactua con el mundo exterior a través de propiedades, señales y slots y que generalmente está definido en su propio archivo QML (Para más detalles puedes ver Defining new Components (Definiendo nuevos componentes))
El nombre del componente siempre debe comenzar con una letra mayúscula.


El código del componente Cell (Cell.qml) es el siguiente:
El código del componente Cell (Cell.qml) es el siguiente:


===Revisión Línea a Línea===
<code> import Qt 4.7


===El componente Cell (Celda)===
Item {
id: container
property alias cellColor: rectangle.color
signal clicked(color cellColor)


El elemento raíz de nuestro componente será de tipo [http://doc.qt.nokia.com/4.7/qml-item.html Item] ''[doc.qt.nokia.com]'' (Elemento) y su id será container. El tipo Item es el elemento más básico de <span class="caps">QML</span> y es frecuentemente utilizado como contenedor para otros elementos.
width: 40; height: 25


Declaramos una propiedad llamada cellColor. Está propiedad será accesible desde fuera del componente y por lo tanto nos permitirá instanciar celdas de distintos colores. Esta propiedas es sólo un alias de una propiedad existente: El color del rectángulo que compone la celda. (Par más información puedes ver [http://doc.qt.nokia.com/4.7/qml-extending-types.html#adding-new-properties Agregar Nuevas Propiedades] ''[doc.qt.nokia.com]'').
Rectangle {
id: rectangle
border.color: "white"
anchors.fill: parent
}
 
MouseArea {
anchors.fill: parent
onClicked: container.clicked(container.cellColor)
}
}</code>
 
=== Revisión Línea a Línea ===
 
=== El componente Cell (Celda) ===
 
<code>
Item {
id: container
property alias cellColor: rectangle.color
signal clicked(color cellColor)
 
width: 40; height: 25</code>
 
El elemento raíz de nuestro componente será de tipo [http://doc.qt.nokia.com/4.7/qml-item.html Item] (Elemento) y su id será container. El tipo Item es el elemento más básico de QML y es frecuentemente utilizado como contenedor para otros elementos.
 
<code> property alias cellColor: rectangle.color<code>
 
Declaramos una propiedad llamada cellColor. Está propiedad será accesible desde fuera del componente y por lo tanto nos permitirá instanciar celdas de distintos colores. Esta propiedas es sólo un alias de una propiedad existente: El color del rectángulo que compone la celda. (Par más información puedes ver [http://doc.qt.nokia.com/4.7/qml-extending-types.html#adding-new-properties Agregar Nuevas Propiedades]).
 
</code> signal clicked(color cellColor)</code>


Definimos una señal de nombre clicked (presionado) para nuestro componente y que tendrá un parámetro de tipo color, llamado color. Usaremos esta señal para cambiar el color del texto desde nuestro archivo main.
Definimos una señal de nombre clicked (presionado) para nuestro componente y que tendrá un parámetro de tipo color, llamado color. Usaremos esta señal para cambiar el color del texto desde nuestro archivo main.
<code>Rectangle {
id: rectangle
border.color: "white"
anchors.fill: parent
}</code>


Definimos un elemento rectángulo que será hijo de nuestro elemento container y definimos sus propiedades.
Definimos un elemento rectángulo que será hijo de nuestro elemento container y definimos sus propiedades.


Nuestro elemento Cell es básicamente un rectángulo de color igual a rectangle.id<br /> La propiedad anchors.fill es una manera conveniente de establecer el tamaño de un elemento. En este caso el elemento rectangle tendrá el mismo tamaño que su padre. (consulte [http://doc.qt.nokia.com/4.7/qml-anchor-layout.html#anchor-layout Layout basado en anclas] ''[doc.qt.nokia.com]'')
<code>MouseArea {
anchors.fill: parent
onClicked: container.clicked(container.cellColor)
}</code>
 
Nuestro elemento Cell es básicamente un rectángulo de color igual a rectangle.id
La propiedad anchors.fill es una manera conveniente de establecer el tamaño de un elemento. En este caso el elemento rectangle tendrá el mismo tamaño que su padre. (consulte [http://doc.qt.nokia.com/4.7/qml-anchor-layout.html#anchor-layout Layout basado en anclas])
 
<code>MouseArea {
anchors.fill: parent
onClicked: container.clicked(container.cellColor)
}</code>
 
Con el fin de cambiar el color del texto cuando presionemos una celda, creamos un elemento [http://doc.qt.nokia.com/4.7/qml-mousearea.html MouseArea] (Área de Mouse/Ratón) que tendrá el mismo tamaño que su padre.
 
El [http://doc.qt.nokia.com/4.7/qml-mousearea.html MouseArea] define una señal clicked esta señal se emita, queremos emitir nuestra propia señal clicked con el color del container como parámetro.
 
=== El archivo main de QML ===
 
En nuestro archivo de QML, usaremos nuestro componente Cell para crear el selector de color:


Con el fin de cambiar el color del texto cuando presionemos una celda, creamos un elemento [http://doc.qt.nokia.com/4.7/qml-mousearea.html MouseArea] ''[doc.qt.nokia.com]'' (Área de Mouse/Ratón) que tendrá el mismo tamaño que su padre.
<code> import Qt 4.7


El [http://doc.qt.nokia.com/4.7/qml-mousearea.html MouseArea] ''[doc.qt.nokia.com]'' define una señal clicked esta señal se emita, queremos emitir nuestra propia señal clicked con el color del container como parámetro.
Rectangle {
id: page
width: 500; height: 200
color: "lightgray"


===El archivo main de <span class="caps">QML</span>===
Text {
id: helloText
text: "Hello world!"
y: 30
anchors.horizontalCenter: page.horizontalCenter
font.pointSize: 24; font.bold: true
}


En nuestro archivo de <span class="caps">QML</span>, usaremos nuestro componente Cell para crear el selector de color:
Grid {
id: colorPicker
x: 4; anchors.bottom: page.bottom; anchors.bottomMargin: 4
rows: 2; columns: 3; spacing: 3
 
Cell { cellColor: "red"; onClicked: helloText.color = cellColor }
Cell { cellColor: "green"; onClicked: helloText.color = cellColor }
Cell { cellColor: "blue"; onClicked: helloText.color = cellColor }
Cell { cellColor: "yellow"; onClicked: helloText.color = cellColor }
Cell { cellColor: "steelblue"; onClicked: helloText.color = cellColor }
Cell { cellColor: "black"; onClicked: helloText.color = cellColor }
}
}</code>


Creamos nuestro selector de color colocando 6 Cells de distinto color en un elemento Grid (tabla/rejllla).
Creamos nuestro selector de color colocando 6 Cells de distinto color en un elemento Grid (tabla/rejllla).


Cuando la señal clicked de alguna Cell se disparé, estableceremos el color del texto que pasamos como parámetro al color del rectángulo que emite la señal.<br /> Podemos reaccionar ante la emisión de cualquier señal de nuestros componentes a través de la propiedad “onNombreDeSeñal”.
<code> Cell { cellColor: "red"; onClicked: helloText.color = cellColor }<code>


==Estados y Transiciones==
Cuando la señal clicked de alguna Cell se disparé, estableceremos el color del texto que pasamos como parámetro al color del rectángulo que emite la señal.
Podemos reaccionar ante la emisión de cualquier señal de nuestros componentes a través de la propiedad "onNombreDeSeñal".
 
== Estados y Transiciones ==


Ahora haremos este ejemplo un poco más dinámico mediante states (estados) y transitions (transiciones). Haremos que nuestro texto se mueva hacia abajo, gire 180 grados y cambie su color a rojo al ser presionado.
Ahora haremos este ejemplo un poco más dinámico mediante states (estados) y transitions (transiciones). Haremos que nuestro texto se mueva hacia abajo, gire 180 grados y cambie su color a rojo al ser presionado.
Line 83: Line 199:
La aplicación final se verá como en la siguiente imagen.
La aplicación final se verá como en la siguiente imagen.


[[Image:declarative-tutorial3_animation.gif]]
[[Image:http://doc.qt.nokia.com/4.7/images/declarative-tutorial3_animation.gif|http://doc.qt.nokia.com/4.7/images/declarative-tutorial3_animation.gif]]


Para ello es necesario cambiar el código de main.qml que quedará de la siguiente forma:
Para ello es necesario cambiar el código de main.qml que quedará de la siguiente forma:


En la línea 17 creamos un nuevo estado llamado down (presionado) para nuestro elemento texto. Este evento será activado cuándo la MouseArea esté presionada y desactivado cuando se deje de presionar.<br /> El estado down incluye un conjunto de cambios a las propiedades de nuestro estado por defecto definido implicitamente (es decir, como fue inicialmente definido). Especificamente, establecemos la propiedad y de text a 160, su rotación a 180 y el color a rojo.
</code> import Qt 4.7
 
Rectangle {
id: page
width: 500; height: 200
color: "lightgray"
 
Text {
id: helloText
text: "Hello world!"
y: 30
anchors.horizontalCenter: page.horizontalCenter
font.pointSize: 24; font.bold: true
 
MouseArea { id: mouseArea; anchors.fill: parent }
 
states: State {
name: "down"; when: mouseArea.pressed == true
PropertyChanges { target: helloText; y: 160; rotation: 180; color: "red" }
}
 
transitions: Transition {
from: ""; to: "down"; reversible: true
ParallelAnimation {
NumberAnimation { properties: "y,rotation"; duration: 500; easing.type: Easing.InOutQuad }
ColorAnimation { duration: 500 }
}
}
}
 
Grid {
id: colorPicker
x: 4; anchors.bottom: page.bottom; anchors.bottomMargin: 4
rows: 2; columns: 3; spacing: 3
 
Cell { cellColor: "red"; onClicked: helloText.color = cellColor }
Cell { cellColor: "green"; onClicked: helloText.color = cellColor }
Cell { cellColor: "blue"; onClicked: helloText.color = cellColor }
Cell { cellColor: "yellow"; onClicked: helloText.color = cellColor }
Cell { cellColor: "steelblue"; onClicked: helloText.color = cellColor }
Cell { cellColor: "black"; onClicked: helloText.color = cellColor }
}
}<code>
 
En la línea 17 creamos un nuevo estado llamado down (presionado) para nuestro elemento texto. Este evento será activado cuándo la MouseArea esté presionada y desactivado cuando se deje de presionar.
El estado down incluye un conjunto de cambios a las propiedades de nuestro estado por defecto definido implicitamente (es decir, como fue inicialmente definido). Especificamente, establecemos la propiedad y de text a 160, su rotación a 180 y el color a rojo.


Ya que no queremos que los cambios de propiedades cambien inmediatamente sino que lo hagan lentamente a través de una animación, definimos una transición entre nuestros dos estados (línea 22). from y to definen los estados inicial y final de la transición. En este caso queremos que la transición ocurra del estado por defecto al estado down.
Ya que no queremos que los cambios de propiedades cambien inmediatamente sino que lo hagan lentamente a través de una animación, definimos una transición entre nuestros dos estados (línea 22). from y to definen los estados inicial y final de la transición. En este caso queremos que la transición ocurra del estado por defecto al estado down.
Line 94: Line 255:


El elemento ParallelAnimation (Animación paralela) se asegura que los dos tipos de animación (propiedades numéricas y el color) comiencen al mismo tiempo. También es posible que cambien una después de la otra utilizando el elemento SequentialAnimation (Animación secuencial).
El elemento ParallelAnimation (Animación paralela) se asegura que los dos tipos de animación (propiedades numéricas y el color) comiencen al mismo tiempo. También es posible que cambien una después de la otra utilizando el elemento SequentialAnimation (Animación secuencial).
Para más detalles sobre estados y transiciones puedes ver <span class="caps">QML</span> States (Estados <span class="caps">QML</span>).
===Categories:===
* [[:Category:Spanish|Spanish]]

Latest revision as of 16:02, 16 March 2015

This article may require cleanup to meet the Qt Wiki's quality standards. Reason: Auto-imported from ExpressionEngine.
Please improve this article if you can. Remove the {{cleanup}} tag and add this page to Updated pages list after it's clean.

Tutorial "Hola Mundo" con QML

Este tutorial provee una introducción a QML, el lenguage de marcado de Qt Quick. Este tutorial no cubre todo; sólo hace énfasis en enseñar principios clave, las funciones se presentan tan pronto sea necesario.

A través de los distintos pasos de este tutorial aprenderemos acerca de los tipos básicos de QML, crearemos nuestros propios componentes QML con propiedades y signals, y crearemos una animación simpmle con la ayuda de estados y transicionnes.

El capítulo uno comienza con un programa mínimo de "Hola mundo" y en los siguientes capítulos presentaremos nuevos conceptos.

El código fuente del tutorial está ubicado en el directorio $QTDIR/examples/declarative/tutorials/helloworld.

Capítulos del tutorial:

  1. Tipos Básicos
  2. Componentes QML
  3. Estados y Transiciones

Tipos Básicos

El primer programa con QML es un simple "Hola mundo" que introduce algunos conceptos básicos de QML. La imagen de abajo muestra una captura de pantalla de este programa.

http://doc.qt.nokia.com/4.7/images/declarative-tutorial1.png

El código QML para esta aplicación es el siguiente:

 import Qt 4.7

Rectangle {
 id: page
 width: 500; height: 200
 color: "lightgray"

Text {
 id: helloText
 text: "Hello world!"
 y: 30
 anchors.horizontalCenter: page.horizontalCenter
 font.pointSize: 24; font.bold: true
 }
 }

Revisión línea a línea

Importar

Primero importamos los tipos necesarios para este ejemplo. Muchos archivos QML importarán los tipos básicos de QML (como Rectangle o Image) utilizando:

import Qt 4.7<code>

=== Elemento Rectangle ===

Rectangle {

id: page
width: 500; height: 200

color: "lightgray"

Declaramos nuestro elemento raíz el cuál será de tipo [http://doc.qt.nokia.com/4.7/qml-rectangle.html Rectangle] (Rectángulo), uno de los tipos básicos de QML. Le asignamos un id con el cuál podremos referirnos a él posteriormente, en este caso le llamaremos page (página). También establecemos sus propiedades de ancho, alto y color mediante las palabras clave width, height y color.
El elemento [http://doc.qt.nokia.com/4.7/qml-rectangle.html Rectangle] tiene muchas otras propiedades (como posición en X y en Y) pero por ahora dejaremos que conserven sus valores por defecto.

=== Elemento Text ===

Definimos un elemento tipo [http://doc.qt.nokia.com/4.7/qml-text.html Text] (Texto), el cuál será hijo del elemento Rectangle raiz y que mostrará el texto "Hello world!" La propiedad Y es utilizada para posicionar el texto de manera vertical a 30 pixeles por debajo de la parte superior de su padre.
Las propiedades font.pointSize (Tamaño de fuente) y font.bold (Negritas) están relacionadas con el tipo Font y es por ello que usan una notación con puntos (Tipo.propiedad).
La propiedad anchors.horizontalCenter (anclas.CentroHorizontal) se refiere al centro horizontal de un elemento. En este caso, especificamos que nuestro elemento helloText debe estar centrado horizontalmente en el elemento page. Consulte [http://doc.qt.nokia.com/4.7/qml-anchor-layout.html#anchor-layout Anchor-based Layout] (Organización basada en anclas)
Las propiedades font.pointSize y font.bold properties están realacionadas con la fuente y utilizan la [http://doc.qt.nokia.com/4.7/qdeclarativeintroduction.html#dot-properties notación de punto].

=== Viendo el ejemplo ===

Para ver el ejemplo, ejecuta la herramienta [http://doc.qt.nokia.com/4.7/qmlviewer.html(localizada QML Viewer] en el directorio bin) con el nombre del archivo como primer argumento. Por ejemplo, para ejecutar el ejemplo desde la localización de la instalación, debes escribir:

bin/qml $QTDIR/examples/declarative/tutorials/helloworld/tutorial.qml

Componentes QML

Ahora agregaremos un selector de color a nuestra aplicación que servirá para cambiar el color de nuestro texto. La aplicación de esta sección del ejemplo se verá como en la siguiente imagen.

http://doc.qt.nokia.com/4.7/images/declarative-tutorial2.png

El selector de color está hecho de seis celdas de distintos colores. Para evitar escribir el código varias veces, primero creamos un nuevo componente llamaco Cell (Celda/Casilla). Los componentes proveen maneras de definir un nuevo tipo que puede ser reutilizado en otros archivos QML. Un componente de QML es como una caja negra que interactua con el mundo exterior a través de propiedades, señales y slots y que generalmente está definido en su propio archivo QML (Para más detalles puedes ver Defining new Components (Definiendo nuevos componentes)) El nombre del componente siempre debe comenzar con una letra mayúscula.

El código del componente Cell (Cell.qml) es el siguiente:

 import Qt 4.7

Item {
 id: container
 property alias cellColor: rectangle.color
 signal clicked(color cellColor)

width: 40; height: 25

Rectangle {
 id: rectangle
 border.color: "white"
 anchors.fill: parent
 }

MouseArea {
 anchors.fill: parent
 onClicked: container.clicked(container.cellColor)
 }
 }

Revisión Línea a Línea

El componente Cell (Celda)

Item {
 id: container
 property alias cellColor: rectangle.color
 signal clicked(color cellColor)

width: 40; height: 25

El elemento raíz de nuestro componente será de tipo Item (Elemento) y su id será container. El tipo Item es el elemento más básico de QML y es frecuentemente utilizado como contenedor para otros elementos.

 property alias cellColor: rectangle.color<code>

Declaramos una propiedad llamada cellColor. Está propiedad será accesible desde fuera del componente y por lo tanto nos permitirá instanciar celdas de distintos colores. Esta propiedas es sólo un alias de una propiedad existente: El color del rectángulo que compone la celda. (Par más información puedes ver [http://doc.qt.nokia.com/4.7/qml-extending-types.html#adding-new-properties Agregar Nuevas Propiedades]).

signal clicked(color cellColor)

Definimos una señal de nombre clicked (presionado) para nuestro componente y que tendrá un parámetro de tipo color, llamado color. Usaremos esta señal para cambiar el color del texto desde nuestro archivo main.

Rectangle {
 id: rectangle
 border.color: "white"
 anchors.fill: parent
}

Definimos un elemento rectángulo que será hijo de nuestro elemento container y definimos sus propiedades.

MouseArea {
 anchors.fill: parent
 onClicked: container.clicked(container.cellColor)
}

Nuestro elemento Cell es básicamente un rectángulo de color igual a rectangle.id La propiedad anchors.fill es una manera conveniente de establecer el tamaño de un elemento. En este caso el elemento rectangle tendrá el mismo tamaño que su padre. (consulte Layout basado en anclas)

MouseArea {
 anchors.fill: parent
 onClicked: container.clicked(container.cellColor)
}

Con el fin de cambiar el color del texto cuando presionemos una celda, creamos un elemento MouseArea (Área de Mouse/Ratón) que tendrá el mismo tamaño que su padre.

El MouseArea define una señal clicked esta señal se emita, queremos emitir nuestra propia señal clicked con el color del container como parámetro.

El archivo main de QML

En nuestro archivo de QML, usaremos nuestro componente Cell para crear el selector de color:

 import Qt 4.7

Rectangle {
 id: page
 width: 500; height: 200
 color: "lightgray"

Text {
 id: helloText
 text: "Hello world!"
 y: 30
 anchors.horizontalCenter: page.horizontalCenter
 font.pointSize: 24; font.bold: true
 }

Grid {
 id: colorPicker
 x: 4; anchors.bottom: page.bottom; anchors.bottomMargin: 4
 rows: 2; columns: 3; spacing: 3

Cell { cellColor: "red"; onClicked: helloText.color = cellColor }
 Cell { cellColor: "green"; onClicked: helloText.color = cellColor }
 Cell { cellColor: "blue"; onClicked: helloText.color = cellColor }
 Cell { cellColor: "yellow"; onClicked: helloText.color = cellColor }
 Cell { cellColor: "steelblue"; onClicked: helloText.color = cellColor }
 Cell { cellColor: "black"; onClicked: helloText.color = cellColor }
 }
 }

Creamos nuestro selector de color colocando 6 Cells de distinto color en un elemento Grid (tabla/rejllla).

 Cell { cellColor: "red"; onClicked: helloText.color = cellColor }<code>

Cuando la señal clicked de alguna Cell se disparé, estableceremos el color del texto que pasamos como parámetro al color del rectángulo que emite la señal.
Podemos reaccionar ante la emisión de cualquier señal de nuestros componentes a través de la propiedad "onNombreDeSeñal".

== Estados y Transiciones ==

Ahora haremos este ejemplo un poco más dinámico mediante states (estados) y transitions (transiciones). Haremos que nuestro texto se mueva hacia abajo, gire 180 grados y cambie su color a rojo al ser presionado.

La aplicación final se verá como en la siguiente imagen.

[[Image:http://doc.qt.nokia.com/4.7/images/declarative-tutorial3_animation.gif|http://doc.qt.nokia.com/4.7/images/declarative-tutorial3_animation.gif]]

Para ello es necesario cambiar el código de main.qml que quedará de la siguiente forma:

import Qt 4.7

Rectangle {

id: page
width: 500; height: 200
color: "lightgray"

Text {

id: helloText
text: "Hello world!"
y: 30
anchors.horizontalCenter: page.horizontalCenter
font.pointSize: 24; font.bold: true

MouseArea { id: mouseArea; anchors.fill: parent }

states: State {

name: "down"; when: mouseArea.pressed == true
PropertyChanges { target: helloText; y: 160; rotation: 180; color: "red" }
}

transitions: Transition {

from: ""; to: "down"; reversible: true
ParallelAnimation {
NumberAnimation { properties: "y,rotation"; duration: 500; easing.type: Easing.InOutQuad }
ColorAnimation { duration: 500 }
}
}
}

Grid {

id: colorPicker
x: 4; anchors.bottom: page.bottom; anchors.bottomMargin: 4
rows: 2; columns: 3; spacing: 3

Cell { cellColor: "red"; onClicked: helloText.color = cellColor }

Cell { cellColor: "green"; onClicked: helloText.color = cellColor }
Cell { cellColor: "blue"; onClicked: helloText.color = cellColor }
Cell { cellColor: "yellow"; onClicked: helloText.color = cellColor }
Cell { cellColor: "steelblue"; onClicked: helloText.color = cellColor }
Cell { cellColor: "black"; onClicked: helloText.color = cellColor }
}
}

En la línea 17 creamos un nuevo estado llamado down (presionado) para nuestro elemento texto. Este evento será activado cuándo la MouseArea esté presionada y desactivado cuando se deje de presionar. El estado down incluye un conjunto de cambios a las propiedades de nuestro estado por defecto definido implicitamente (es decir, como fue inicialmente definido). Especificamente, establecemos la propiedad y de text a 160, su rotación a 180 y el color a rojo.

Ya que no queremos que los cambios de propiedades cambien inmediatamente sino que lo hagan lentamente a través de una animación, definimos una transición entre nuestros dos estados (línea 22). from y to definen los estados inicial y final de la transición. En este caso queremos que la transición ocurra del estado por defecto al estado down.

Debido a que queremos que la misma transición se ejecute en reversa al regresar del estado down al estado por defecto, establecemos la propiedad reversible a true (verdadero). Esto es equivalente a escribir dos transiciones por separado, una para cada estado como origen y destino.

El elemento ParallelAnimation (Animación paralela) se asegura que los dos tipos de animación (propiedades numéricas y el color) comiencen al mismo tiempo. También es posible que cambien una después de la otra utilizando el elemento SequentialAnimation (Animación secuencial).