2010


Últimamente hay mucho revuelo y movimiento relacionado a lo que es mobile, pero de todo ese ruido muy pocas cosas son realmente originales o proponen un cambio de paradigma, una de esas excepciones es la nueva UI de Windows Phone 7 y aunque posiblemente nunca compre, use o desarrolle para WP7 hay un par de conceptos interesantes que me gustaría tomar prestados, como por ejemplo los controles Panorama (ver imagen abajo) y Pivot para poder usarlos en mis aplicaciones QML.

Vamos a comenzar con el control Panorama, implementarlo no es para nada complicado, como verán hay algunas propiedades para configurar el look and feel, el contenido o el elemento que hará de contenedor de los PanoramaItems, también tenemos un control Flickable que utilizaremos para mover horizontalmente los PanoramaItems hijos y para finalizar tenemos un elemento Text que usaremos para mostrar el titulo del control Panorama y una Grid en donde se irán acomodando los PanoramaItems.
import Qt 4.7
Rectangle {
id: container
width:parent.width
height:parent.height
default property alias content: content.children
property string title: "panorama"
property int titleSize:48
property string titleFont: ""
property color titleColor:"#fff"
property color background:"#333"
property string backgroundImage:""
property string backgroundFillMode:"Tile"
color: container.background
Flickable {
width:parent.width
height:parent.height
contentWidth: content.width;
contentHeight: container.height
boundsBehavior: "StopAtBounds"
Image{
source: container.backgroundImage
fillMode: container.backgroundFillMode
Grid{
width: content.width
height: content.height
rows:2
Text {
id: title
text: container.title
font.pointSize: container.titleSize
font.family: container.titleFont
color: container.titleColor
}
Grid {
id: content
spacing:10
}
}
}
}
}
El control PanoramaItem es aun mas sencillo como se ve en el código a continuación.
import Qt 4.7
Item {
id: container
default property alias content: content.children
property string title: "panoramaItem"
property int titleSize: 21
property color titleColor: "#fff"
height: wrapper.height
Grid{
id: wrapper
rows:2
Text {
id: title
width: container.width
text: container.title
smooth: true
wrapMode: "Wrap"
font.pointSize: container.titleSize
color: container.titleColor
}
Rectangle {
id: content
width: container.width
height: container.height - title.height
}
}
}
Bien, ahora que ya tenemos nuestros controles, es momento de usarlos, para ello solo debemos crear un control Panorama, establecer el titulo, el tipo y tamaño del font, una imagen de fondo si es que vamos a usar una, para luego agregar los PanoramaItems que deseemos con su respectivos contenidos.
import Qt 4.7
Rectangle {
id: screen
width: 360
height: 640
Panorama{
id:myPanorama
title: "my Panorama"
backgroundImage:"images/bg.jpg"
PanoramaItem{
width: screen.width -30
title:"first item"
titleSize: 21
// Content here
}
PanoramaItem{
width: screen.width
title:"second Item"
titleSize: 21
// Content here
}
PanoramaItem{
width: screen.width
title:"third Item"
titleSize: 21
// Content here
}
}
}
En la imagen a continuación pueden ver el resultado de el ejemplo y en el vídeo su funcionamiento.

Como verán duplicar el comportamiento básico de estos controles no fue para nada difícil, aunque esto es solo un simple ejemplo, con muchas cosas aun por pulir y funcionalidades por implementar para lograr una emulación completa de las funcionalidades de los controles originales, aun sirve para demostrar la capacidades de QML y como con poco código se pueden lograr resultados interesantes.
Ayer se libero la Technology Preview de Qt Mobility 1.2, ademas del código fuente, esta versión viene acompañaba de paquetes RPM para dispositivos compatibles con MeeGo (no así de paquetes SIS para Symbian, si desean usar esta TP en Symbian deberán compilarlo ustedes mismos), el objetivo principal de esta versión es el soporte para MeeGo y se espera que este finalizada justo para el lanzamiento de MeeGo 1.2 en abril del año que viene.
sudo zypper addrepo http://download.meego.com/live/devel:/qt-mtf:/qt-mobility:/1.2tp1/testing/ mobility-1.2-tp1 sudo zypper addrepo http://download.meego.com/live/Trunk:/Testing/standard/ trunk-testing sudo zypper refresh sudo zypper install qt-mobility sudo zypper install qt-mobility-examples
Si desean mantenerse actualizados de los cambios, pueden acceder a los repositorios oficiales en:
Para mas información acerca de las novedades de esta versión y de los problemas conocidos no dejen de leer el anuncio de lanzamiento, en cambio si son nuevos en Qt Mobility el vídeo a continuación es una buena introducción.
Hace unos días escribía sobre como colaborar con Qt, pues a la lista anterior debemos ahora agregar el grupo Qt Latam en Qt Developer Network, la función de grupos fue presentada hoy y aun esta en beta, así que si se unen y encuentran algún problema o tienen alguna idea interesante que puede ser incorporada solo tienen que dejar su feedback.
El grupo de Qt Latam pronto va a contar con su propia sección en los foros de Qt DevNet y si los miembros así lo requieren podemos tener nuestra propia wiki, independiente de la wiki oficial de Qt DevNet, esta es la primera iteración de la función de grupos, mas funcionalidades se irán agregando en el futuro.
Así que ya saben, hay un nuevo espacio para seguir aprendiendo y colaborando, los espero.

Colaborar con un proyecto Open Source puede sonar intimidante, uno se imagina que la única forma de hacerlo es aportando código y que tiene que pasar por el escrutinio de hackers veteranos antes de poder hacer alguna contribución que agregue valor al proyecto, nada mas alejado de la realidad, ya que un proyecto Open Source no todo es código, hay muchas áreas en las que uno puede colaborar, lo importante es tener ganas y saber como y donde hacerlo.
La comunidad que gira en torno a Qt tiene sus años y esta madura y bien organizada pero ello no quita que haya muchas cosas aún por hacer, a continuación tienen un lista de lugares y las respectivas tareas que pueden realizar en ellos.
| ¿Donde? | ¿Como? |
|---|---|
| Qt Forums | Preguntando y contestando dudas, dándole la bienvenida a los nuevos usuarios, puntuando posts. |
| Qt Wiki | Creando, corrigiendo o traduciendo contenido, valorando y agregando tags a los artículos. |
| Bugs Report (Jira) | Reportando, comentando y votando bugs, también puedes pedir nuevas características y dejarlas a consideración del equipo de desarrollo y de la comunidad. |
| Qt Mailing Lists | Subscribiendote a los temas de tu interés, proponiendo temas o respondiendo preguntas, aportando tu experiencia. |
| Qt DevNet Blog | Envíando feedback y compartiendo tu opinión acerca de las novedades de la comunidad. |
| Siguiendo miembros de la comunidad y compartiendo con tus contactos las novedades acerca de Qt. | |
| IRC (#qt , #qt-labs, #qt-creator) | Participando en discusiones con el equipo de desarrollo de Qt, preguntando y compartiendo tu conocimiento con el resto de los integrantes. |
| Traducir Qt (i18n & l10n) | Ayudando a traducir y localizar Qt. |
| Aporta código a Qt. | Colaborando con parches, aportando feedback. |
También puedes colaborar creando un blog, contando tus experiencias, escribiendo tutoriales, aplicaciones de ejemplo, grabando screencasts y participando en grupos locales y asistiendo a charlas.
Como ves hay muchas formas de colaborar con Qt y en el siguiente vídeo Alexandra Leisse repasa estas y otras maneras para comenzar a ayudar y pasar a ser un miembro activo de la comunidad Qt.