Getting Started on the Commandline/es: Difference between revisions

From Qt Wiki
Jump to navigation Jump to search
No edit summary
 
No edit summary
Line 1: Line 1:
=Introducción a la Programación con Qt=
[[Category:Learning]] [[Category:Spanish]]


Bienvenido al mundo de Qt, la herramienta multiplataforma para <span class="caps">GUI</span> (interfaz gráficas de usuario). En esta guía de introducción, aprenderemos temas básicos de Qt mediante la implementación de una simple aplicación Notepad (Bloc de Notas). Al terminar de leer esta guía, usted debería estar listo para ahondar en nuestras descripciones tecnológicas generales y en la documentación del <span class="caps">API</span>, para poder encontrar la información que necesite sobre la aplicación que esté desarrollando.
= Introducción a la Programación con Qt =


==Hola Bloc de Notas==
Bienvenido al mundo de Qt, la herramienta multiplataforma para GUI (interfaz gráficas de usuario). En esta guía de introducción, aprenderemos temas básicos de Qt mediante la implementación de una simple aplicación Notepad (Bloc de Notas). Al terminar de leer esta guía, usted debería estar listo para ahondar en nuestras descripciones tecnológicas generales y en la documentación del API, para poder encontrar la información que necesite sobre la aplicación que esté desarrollando.


En este primer ejemplo, simplemente creamos y mostramos en el escritorio, un editor de texto dentro de un marco de ventana. Esto representa el programa más simple posible de Qt que posea <span class="caps">GUI</span>.
== Hola Bloc de Notas ==


[[Image:gs1.png]]
En este primer ejemplo, simplemente creamos y mostramos en el escritorio, un editor de texto dentro de un marco de ventana. Esto representa el programa más simple posible de Qt que posea GUI.


Este es el código:<br />
[[Image:http://doc.qt.nokia.com/4.7/images/gs1.png|http://doc.qt.nokia.com/4.7/images/gs1.png]]


Revisemos el código línea por línea. En las primeras dos líneas, incluimos los archivos de cabecera de [http://doc.qt.nokia.com/4.7/qapplication.html QApplication] ''[doc.qt.nokia.com]'' y [http://doc.qt.nokia.com/4.7/qtextedit.html QTextEdit] ''[doc.qt.nokia.com]'', las cuales son las dos clases que necesitamos para este ejemplo. Todas las clases de Qt tienen un archivo de cabecera que lleva su nombre.
Este es el código:<br /><code>#include &lt;QApplication&amp;gt;<br />#include &lt;QTextEdit&amp;gt;


En la línea 6 creamos un objeto de la clase [http://doc.qt.nokia.com/4.7/qapplication.html QApplication] ''[doc.qt.nokia.com]''. Este objeto administra los recursos de la aplicación y es necesario para ejecutar cualquier programa de Qt que tenga <span class="caps">GUI</span>. Necesita '''argv''' y '''argc''' debido a que Qt acepta algunos argumentos de la línea de comandos.
int main(int argv, char **args)<br />{<br /> QApplication app(argv, args);


En la línea 8 creamos un objeto de la clase [http://doc.qt.nokia.com/4.7/qtextedit.html QTextEdit] ''[doc.qt.nokia.com]''. Un editor de texto es un elemento visual en la interfaz gráfica. En Qt, estos elementos se conocen con el nombre de widgets. Otros ejemplos de widgets son: barras de desplazamiento, etiquetas, y botones de radio. Un widget también puede ser un contenedor para otros widgets; un diálogo o la ventana principal de una aplicación, por ejemplo.
QTextEdit textEdit;<br /> textEdit.show();


En la línea 9 mostramos el editor de texto en la pantalla en su propio marco de ventana. Debido a que los widgets también funcionan como contenedores (por ejemplo una [http://doc.qt.nokia.com/4.7/qmainwindow.html QMainWindow] ''[doc.qt.nokia.com]'', la cual tiene barras de herramientas, menús, una barra de estatus, y algunos otros widgets), es posible mostrar un solo widget en su propia ventana. Los widgets no son visibles por defecto, la función show() hace visibles los widgets.
return app.exec&amp;amp;#40;&amp;#41;;<br />}</code>


En la línea 11 la [http://doc.qt.nokia.com/4.7/qapplication.html QApplication] ''[doc.qt.nokia.com]'' entra en su ciclo de eventos. Cuando una aplicación de Qt se está ejecutando, los eventos son generados y enviados a los widgets de la aplicación. Algunos ejemplos de eventos son presionar algún botón del mouse y pulsar alguna tecla. Cuando usted escribe texto en el widget editor de texto, este recibe eventos de tecla presionada y responde dibujando el texto tecleado.
Revisemos el código línea por línea. En las primeras dos líneas, incluimos los archivos de cabecera de &quot;QApplication&amp;quot;:http://doc.qt.nokia.com/4.7/qapplication.html y &quot;QTextEdit&amp;quot;:http://doc.qt.nokia.com/4.7/qtextedit.html, las cuales son las dos clases que necesitamos para este ejemplo. Todas las clases de Qt tienen un archivo de cabecera que lleva su nombre.


Para ejecutar la aplicación, ejecute una terminal o símbolo del sistema en (Windows), y entre al directorio en el cual tiene el archivo .cpp del programa. Los siguientes comandos de shell construyen el programa.<br />
En la línea 6 creamos un objeto de la clase &quot;QApplication&amp;quot;:http://doc.qt.nokia.com/4.7/qapplication.html. Este objeto administra los recursos de la aplicación y es necesario para ejecutar cualquier programa de Qt que tenga GUI. Necesita '''argv''' y '''argc''' debido a que Qt acepta algunos argumentos de la línea de comandos.


Esto generará un ejecutable en el directorio part1 (note que en Windows, posiblemente tenga que utilizar nmake en lugar de make. Note, que el ejecutable estará localizado en part1/debug o part1/release).<br /> Qmake es la herramienta de construcción de proyectos de Qt, el cual, utiliza un archivo de configuración. Qmake genera este archivo por nosotros cuando le enviamos el argumento '''-project'''. Dado el archivo de configuración (con el sufijo .pro), qmake produce un archivo make el cual, construirá el programa por usted. Más adelante veremos como escribir nuestros propios archivos .pro
En la línea 8 creamos un objeto de la clase &quot;QTextEdit&amp;quot;:http://doc.qt.nokia.com/4.7/qtextedit.html. Un editor de texto es un elemento visual en la interfaz gráfica. En Qt, estos elementos se conocen con el nombre de widgets. Otros ejemplos de widgets son: barras de desplazamiento, etiquetas, y botones de radio. Un widget también puede ser un contenedor para otros widgets; un diálogo o la ventana principal de una aplicación, por ejemplo.


===Aprender Más===
En la línea 9 mostramos el editor de texto en la pantalla en su propio marco de ventana. Debido a que los widgets también funcionan como contenedores (por ejemplo una &quot;QMainWindow&amp;quot;:http://doc.qt.nokia.com/4.7/qmainwindow.html, la cual tiene barras de herramientas, menús, una barra de estatus, y algunos otros widgets), es posible mostrar un solo widget en su propia ventana. Los widgets no son visibles por defecto, la función show() hace visibles los widgets.


* Widgets y Geometría de Ventanas – [http://doc.qt.nokia.com/4.7/application-windows.html Widgets Diálogo y Ventana] ''[doc.qt.nokia.com]''
En la línea 11 la &quot;QApplication&amp;quot;:http://doc.qt.nokia.com/4.7/qapplication.html entra en su ciclo de eventos. Cuando una aplicación de Qt se está ejecutando, los eventos son generados y enviados a los widgets de la aplicación. Algunos ejemplos de eventos son presionar algún botón del mouse y pulsar alguna tecla. Cuando usted escribe texto en el widget editor de texto, este recibe eventos de tecla presionada y responde dibujando el texto tecleado.
* Eventos y manejo de eventos – [http://doc.qt.nokia.com/4.7/eventsandfilters.html El Sistema de Eventos] ''[doc.qt.nokia.com]''


==Agregando un botón Salir (Quit)==
Para ejecutar la aplicación, ejecute una terminal o símbolo del sistema en (Windows), y entre al directorio en el cual tiene el archivo .cpp del programa. Los siguientes comandos de shell construyen el programa.<br /><code><br />qmake <s>project<br />qmake<br /> make<br /></code>
<br />Esto generará un ejecutable en el directorio part1 (note que en Windows, posiblemente tenga que utilizar nmake en lugar de make. Note, que el ejecutable estará localizado en part1/debug o part1/release).<br />Qmake es la herramienta de construcción de proyectos de Qt, el cual, utiliza un archivo de configuración. Qmake genera este archivo por nosotros cuando le enviamos el argumento '''<s>project*. Dado el archivo de configuración (con el sufijo .pro), qmake produce un archivo make el cual, construirá el programa por usted. Más adelante veremos como escribir nuestros propios archivos .pro
<br />h3. Aprender Más
<br />* Widgets y Geometría de Ventanas</s> &quot;Widgets Diálogo y Ventana&amp;quot;:http://doc.qt.nokia.com/4.7/application-windows.html<br />''' Eventos y manejo de eventos</s> &quot;El Sistema de Eventos&amp;quot;:http://doc.qt.nokia.com/4.7/eventsandfilters.html


En una aplicación real, normalmente necesitará más de un widget. Vamos ahora a agregar un [http://doc.qt.nokia.com/4.7/qpushbutton.html QPushButton] ''[doc.qt.nokia.com]'' debajo del editor de texto. El botón hará que la aplicación Bloc de Notas finalice cuando sea presionado (ejemplo, se da click con el mouse).
== Agregando un botón Salir (Quit) ==


[[Image:gs2.png]]
En una aplicación real, normalmente necesitará más de un widget. Vamos ahora a agregar un &quot;QPushButton&amp;quot;:http://doc.qt.nokia.com/4.7/qpushbutton.html debajo del editor de texto. El botón hará que la aplicación Bloc de Notas finalice cuando sea presionado (ejemplo, se da click con el mouse).


Revisemos el código.<br />
[[Image:http://doc.qt.nokia.com/4.7/images/gs2.png|http://doc.qt.nokia.com/4.7/images/gs2.png]]


La línea 1 incluye el archivo de cabecera [http://doc.qt.nokia.com/4.7/qtgui.html QtGui] ''[doc.qt.nokia.com]'', el cual contiene todas las clases de <span class="caps">GUI</span> de Qt.
Revisemos el código.<br /><code><br />#include &lt;QtGui&amp;gt;


La línea 10 utiliza el mecanismo de '''Signals''' y '''Slots''' de Qt para hacer que la aplicación termine cuando el '''botón Quit''' sea presionado. Un '''slot''' es una función que puede ser invocada en tiempo de ejecución utilizando su nombre (como una cadena de caracteres literal). Una '''signal''' es una función que invoca a los slots registrados con ella, cuando es llamada; Invocamos eso para conectar el slot con la signal y emitir la signal.
int main(int argv, char **args)<br />{<br /> QApplication app(argv, args);


[http://doc.qt.nokia.com/4.7/qcoreapplication.html#quit quit()] ''[doc.qt.nokia.com]'' es un slot de [http://doc.qt.nokia.com/4.7/qapplication.html QApplication] ''[doc.qt.nokia.com]'' que termina la aplicación. [http://doc.qt.nokia.com/4.7/qabstractbutton.html#clicked clicked()] ''[doc.qt.nokia.com]'' es una signal que [http://doc.qt.nokia.com/4.7/qpushbutton.html QPushButton] ''[doc.qt.nokia.com]'' emite cuando es presionado. La función estática [http://doc.qt.nokia.com/4.7/qobject.html#connect QObject::connect()] ''[doc.qt.nokia.com]'' se encarga de conectar el slot a la signal. <span class="caps">SIGNAL</span>() y <span class="caps">SLOT</span>() son dos macros que reciben la firma de las funciones signal y slot a conectar. También necesitamos enviar apuntadores a los objetos que deben enviar y recibir la señal.
QWidget window;


En la línea 12 creamos un [http://doc.qt.nokia.com/4.7/qvboxlayout.html QVBoxLayout] ''[doc.qt.nokia.com]''. Como mencionamos, los widgets pueden contener otros widgets. Es posible establecer los límites (la localización y el tamaño) de los widgets hijos directamente, pero usualmente es más sencillo utilizar un layout. Un layout administra los límites de los widgets hijos. [http://doc.qt.nokia.com/4.7/qvboxlayout.html QVBoxLayout] ''[doc.qt.nokia.com]'', por ejemplo, coloca los hijos en una fila vertical.
QTextEdit *textEdit = new QTextEdit(&amp;window);<br /> QPushButton *quitButton = new QPushButton(&quot;Quit&amp;quot;);


Las líneas 13 y 14 agregan el editor de texto y el botón al layout. En la línea 17, establecemos el layout sobre el widget.
QObject::connect(quitButton, SIGNAL (clicked()), qApp, SLOT (quit()));


===Aprender Más===
QVBoxLayout layout;<br /> layout.addWidget(textEdit);<br /> layout.addWidget(quitButton);


* Signals y slots – [http://doc.qt.nokia.com/4.7/signalsandslots.html Signals &amp; Slots] ''[doc.qt.nokia.com]''
window.setLayout(&amp;layout);
* Layouts – [http://doc.qt.nokia.com/4.7/layout.html Administración de Layout] ''[doc.qt.nokia.com]'', [http://doc.qt.nokia.com/4.7/widgets-and-layouts.html Widgets y Layouts] ''[doc.qt.nokia.com]'', [http://doc.qt.nokia.com/4.7/examples-layouts.html Ejemplos de Layout] ''[doc.qt.nokia.com]''
* Los widgets que se incluyen con Qt – [http://doc.qt.nokia.com/4.7/gallery.html Galería de Widgets de Qt] ''[doc.qt.nokia.com]'', [http://doc.qt.nokia.com/4.7/examples-widgets.html Ejemplos de Widgets] ''[doc.qt.nokia.com]''


==Crear Una Subclase de QWidget==
window.show();


Cuando el usuario quiere salir de una aplicación, es muy normal mostrar un diálogo que le pregunte sobre si de verdad desea salir. En este ejemplo, crearemos una subclase de QWidget, y agregaremos un slot que conectaremos al '''botón Quit'''.
return app.exec&amp;amp;#40;&amp;#41;;<br />}<br /></code>


[[Image:gs3.png]]
La línea 1 incluye el archivo de cabecera &quot;QtGui&amp;quot;:http://doc.qt.nokia.com/4.7/qtgui.html, el cual contiene todas las clases de GUI de Qt.


Revisemos el código:<br />
La línea 10 utiliza el mecanismo de '''Signals''' y '''Slots''' de Qt para hacer que la aplicación termine cuando el '''botón Quit''' sea presionado. Un '''slot''' es una función que puede ser invocada en tiempo de ejecución utilizando su nombre (como una cadena de caracteres literal). Una '''signal''' es una función que invoca a los slots registrados con ella, cuando es llamada; Invocamos eso para conectar el slot con la signal y emitir la signal.


La macro Q_OBJECT debe estar primero en la definición de la clase, y declara nuestra clase como un QObject (Naturalmente, también debe de heredar de [http://doc.qt.nokia.com/4.7/qobject.html QObject] ''[doc.qt.nokia.com]''). Un [http://doc.qt.nokia.com/4.7/qobject.html QObject] ''[doc.qt.nokia.com]'' añade varias capacidades a una clase normal de C++. Notablemente, el nombre de la clase y los nombres de los slots pueden ser consultados en tiempo de ejecución. También es posible consultar el tipo de los parámetros de un slot e invocarlo.
&quot;quit()&quot;:http://doc.qt.nokia.com/4.7/qcoreapplication.html#quit es un slot de &quot;QApplication&amp;quot;:http://doc.qt.nokia.com/4.7/qapplication.html que termina la aplicación. &quot;clicked()&quot;:http://doc.qt.nokia.com/4.7/qabstractbutton.html#clicked es una signal que &quot;QPushButton&amp;quot;:http://doc.qt.nokia.com/4.7/qpushbutton.html emite cuando es presionado. La función estática &quot;QObject::connect()&quot;:http://doc.qt.nokia.com/4.7/qobject.html#connect se encarga de conectar el slot a la signal. SIGNAL&amp;amp;#40;&amp;#41; y SLOT&amp;amp;#40;&amp;#41; son dos macros que reciben la firma de las funciones signal y slot a conectar. También necesitamos enviar apuntadores a los objetos que deben enviar y recibir la señal.


La línea 13 declara el '''slot quit()'''. Esto es sencillo utilizando la marco '''slots'''. El '''slot quit()''' ahora puede conectarse a las '''signals''' que coincidan en su firma (cualquier signal que no reciba parámetros).
En la línea 12 creamos un &quot;QVBoxLayout&amp;quot;:http://doc.qt.nokia.com/4.7/qvboxlayout.html. Como mencionamos, los widgets pueden contener otros widgets. Es posible establecer los límites (la localización y el tamaño) de los widgets hijos directamente, pero usualmente es más sencillo utilizar un layout. Un layout administra los límites de los widgets hijos. &quot;QVBoxLayout&amp;quot;:http://doc.qt.nokia.com/4.7/qvboxlayout.html, por ejemplo, coloca los hijos en una fila vertical.


En lugar de configurar la interfaz gráfica y conectar el slot en la función main(), ahora utilizamos el constructor del Bloc de Notas.
Las líneas 13 y 14 agregan el editor de texto y el botón al layout. En la línea 17, establecemos el layout sobre el widget.


Como se puede ver en la definición de la clase, utilizamos apuntadores (punteros) a nuestros [http://doc.qt.nokia.com/4.7/qobject.htmls QObject] ''[doc.qt.nokia.com]'' (textEdit y quitButton) Como regla, usted siempre debe reservar memoria para [http://doc.qt.nokia.com/4.7/qobject.htmls QObject] ''[doc.qt.nokia.com]'' en el heap y nunca copiarlos.
=== Aprender Más ===


Ahora utilizamos la función [http://doc.qt.nokia.com/4.7/qobject.html#tr tr()] ''[doc.qt.nokia.com]'' alrededor de las cadenas de texto que serán visibles por el usuario. Esta función es necesaria cuando usted desea proveer su aplicación en más de un lenguaje (ejemplo, Inglés y Chino) No entraremos en detalles aquí, pero puede consultar el enlace Qt Linguist de la tabla de aprenda más.
* Signals y slots - &quot;Signals &amp; Slots&amp;quot;:http://doc.qt.nokia.com/4.7/signalsandslots.html
* Layouts - &quot;Administración de Layout&amp;quot;:http://doc.qt.nokia.com/4.7/layout.html, &quot;Widgets y Layouts&amp;quot;:http://doc.qt.nokia.com/4.7/widgets-and-layouts.html, &quot;Ejemplos de Layout&amp;quot;:http://doc.qt.nokia.com/4.7/examples-layouts.html
* Los widgets que se incluyen con Qt - &quot;Galería de Widgets de Qt&amp;quot;:http://doc.qt.nokia.com/4.7/gallery.html, &quot;Ejemplos de Widgets&amp;quot;:http://doc.qt.nokia.com/4.7/examples-widgets.html


===Aprender Más===
== Crear Una Subclase de QWidget ==


* tr() e internacionalización – [http://doc.qt.nokia.com/4.7/linguist-manual.html Manual Qt Linguist] ''[doc.qt.nokia.com]'', [http://doc.qt.nokia.com/4.7/i18n-source-translation.html Escribiendo Código Fuente Para Traducción] ''[doc.qt.nokia.com]'', [http://doc.qt.nokia.com/4.7/linguist-hellotr.html Ejemplo Hola tr()] ''[doc.qt.nokia.com]'', [http://doc.qt.nokia.com/4.7/internationalization.html Internacionalización con Qt] ''[doc.qt.nokia.com]''
Cuando el usuario quiere salir de una aplicación, es muy normal mostrar un diálogo que le pregunte sobre si de verdad desea salir. En este ejemplo, crearemos una subclase de QWidget, y agregaremos un slot que conectaremos al '''botón Quit'''.
* [http://doc.qt.nokia.com/4.7/qtwebkit-bridge.html#qobjects QObjects] ''[doc.qt.nokia.com]'' y el Modelo de Objetos de Qt (Esto es esencial para entender Qt) – [http://doc.qt.nokia.com/4.7/object.html Modelo de Objetos] ''[doc.qt.nokia.com]''
* qmake y el sistema de construcción de Qt – [http://doc.qt.nokia.com/4.7/qmake-manual.html Manual qmake] ''[doc.qt.nokia.com]''


==Creando un archivo .pro==
[[Image:http://doc.qt.nokia.com/4.7/images/gs3.png|http://doc.qt.nokia.com/4.7/images/gs3.png]]


Para este ejemplo escribiremos nuestro archivo en lugar de utilizar la opción de qmake -project
Revisemos el código:<br /><code>class Notepad : public QWidget<br />{<br /> Q_OBJECT


Los siguientes comandos de shell construyen el ejemplo<br />
public:<br /> Notepad();


==Usando una QMainWindow==
private slots:<br /> void quit();


Muchas aplicaciones se beneficiarán del uso de un [http://doc.qt.nokia.com/4.7/qmainwindow.html QMainWindow] ''[doc.qt.nokia.com]'', la cual tiene su propio layout al cual puede agregar una barra de menús, widgets de acoplamiento (dock widgets), barras de herramientas, y una barra de estado. [http://doc.qt.nokia.com/4.7/qmainwindow.html QMainWindow] ''[doc.qt.nokia.com]'' tiene un área central que puede ser ocupada por cualquier tipo de widget. En nuestro caso, vamos a ubicar nuestro editor de texto aquí.
private:<br /> QTextEdit *textEdit;<br /> QPushButton *quitButton;<br />};</code>


[[Image:gs4.png]]
La macro Q_OBJECT debe estar primero en la definición de la clase, y declara nuestra clase como un QObject (Naturalmente, también debe de heredar de &quot;QObject&amp;quot;:http://doc.qt.nokia.com/4.7/qobject.html). Un &quot;QObject&amp;quot;:http://doc.qt.nokia.com/4.7/qobject.html añade varias capacidades a una clase normal de C++. Notablemente, el nombre de la clase y los nombres de los slots pueden ser consultados en tiempo de ejecución. También es posible consultar el tipo de los parámetros de un slot e invocarlo.


Revisemos la nueva definición de la clase Bloc de Notas (Notepad)
La línea 13 declara el '''slot quit()'''. Esto es sencillo utilizando la marco '''slots'''. El '''slot quit()''' ahora puede conectarse a las '''signals''' que coincidan en su firma (cualquier signal que no reciba parámetros).


Incluimos dos '''slots''' más que pueden guardar y abrir un documento. Implementaremos su funcionalidad en la siguiente sección.
En lugar de configurar la interfaz gráfica y conectar el slot en la función main(), ahora utilizamos el constructor del Bloc de Notas.


A menudo, en una ventana principal (main window), el mismo '''slot''' debe ser invocado por varios widgets. Ejemplos de ello son los elementos de menú y los botones en una barra de herramientas. Para hacer esto más fácil, Qt proporciona [http://doc.qt.nokia.com/4.7/qaction.html QAction] ''[doc.qt.nokia.com]'', que puede ser dada a varios widgets, y ser conectada a un slot. Por ejemplo, tanto [http://doc.qt.nokia.com/4.7/qmenu.html QMenu] ''[doc.qt.nokia.com]'' como [http://doc.qt.nokia.com/4.7/qtoolbar.html QToolBar] ''[doc.qt.nokia.com]'' pueden crear elementos de menú y botones de herramientas de las mismas [http://doc.qt.nokia.com/4.7/qaction.htmls QAction] ''[doc.qt.nokia.com]''. En breve vamos a ver como funciona esto.
<code>Notepad::Notepad()<br />{<br /> textEdit = new QTextEdit;<br /> quitButton = new QPushButton(tr(&quot;Quit&amp;quot;));


Como antes, usamos el constructor del Bloc de Notas (Notepad) para configurar la <span class="caps">GUI</span>.
connect(quitButton, SIGNAL (clicked()), this, SLOT (quit()));


Las [http://doc.qt.nokia.com/4.7/qaction.htmls QAction] ''[doc.qt.nokia.com]'' son creadas con el texto que debe aparecer en los widgets a los que las adicionemos (en nuestro caso, los elementos de menú). Si también quisieramos añadirlos a una barra de herramientas, podríamos haberles dado [http://doc.qt.nokia.com/4.7/qaction.html iconos] ''[doc.qt.nokia.com]'' a las acciones (actions).
QVBoxLayout '''layout = new QVBoxLayout;<br /> layout-&gt;addWidget(textEdit);<br /> layout-&gt;addWidget(quitButton);
<br /> setLayout(layout);
<br /> setWindowTitle(tr(&quot;Notepad&amp;quot;));<br />}</code>
<br />Como se puede ver en la definición de la clase, utilizamos apuntadores (punteros) a nuestros &quot;QObject&amp;quot;:http://doc.qt.nokia.com/4.7/qobject.htmls (textEdit y quitButton) Como regla, usted siempre debe reservar memoria para &quot;QObject&amp;quot;:http://doc.qt.nokia.com/4.7/qobject.htmls en el heap y nunca copiarlos.
<br />Ahora utilizamos la función &quot;tr()&quot;:http://doc.qt.nokia.com/4.7/qobject.html#tr alrededor de las cadenas de texto que serán visibles por el usuario. Esta función es necesaria cuando usted desea proveer su aplicación en más de un lenguaje (ejemplo, Inglés y Chino) No entraremos en detalles aquí, pero puede consultar el enlace Qt Linguist de la tabla de aprenda más.
<br />h3. Aprender Más
<br />''' tr() e internacionalización - &quot;Manual Qt Linguist&amp;quot;:http://doc.qt.nokia.com/4.7/linguist-manual.html, &quot;Escribiendo Código Fuente Para Traducción&amp;quot;:http://doc.qt.nokia.com/4.7/i18n-source-translation.html, &quot;Ejemplo Hola tr()&quot;:http://doc.qt.nokia.com/4.7/linguist-hellotr.html, &quot;Internacionalización con Qt&amp;quot;:http://doc.qt.nokia.com/4.7/internationalization.html<br />* &quot;QObjects&amp;quot;:http://doc.qt.nokia.com/4.7/qtwebkit-bridge.html#qobjects y el Modelo de Objetos de Qt (Esto es esencial para entender Qt) - &quot;Modelo de Objetos&amp;quot;:http://doc.qt.nokia.com/4.7/object.html<br />* qmake y el sistema de construcción de Qt - &quot;Manual qmake&amp;quot;:http://doc.qt.nokia.com/4.7/qmake-manual.html


Cuando un elemento de menú es presionado, el elemento dispara la accion, y el respectivo slot se invocará.
== Creando un archivo .pro ==


===Aprender Más===
Para este ejemplo escribiremos nuestro archivo en lugar de utilizar la opción de qmake <s>project
<br /><code><br />HEADERS = notepad.h<br />SOURCES = notepad.cpp main.cpp<br /></code>
<br />Los siguientes comandos de shell construyen el ejemplo<br /><code><br />qmake<br />make<br /></code>
<br />h2. Usando una QMainWindow
<br />Muchas aplicaciones se beneficiarán del uso de un &quot;QMainWindow&amp;quot;:http://doc.qt.nokia.com/4.7/qmainwindow.html, la cual tiene su propio layout al cual puede agregar una barra de menús, widgets de acoplamiento (dock widgets), barras de herramientas, y una barra de estado. &quot;QMainWindow&amp;quot;:http://doc.qt.nokia.com/4.7/qmainwindow.html tiene un área central que puede ser ocupada por cualquier tipo de widget. En nuestro caso, vamos a ubicar nuestro editor de texto aquí.
<br />[[Image:http://doc.qt.nokia.com/4.7/images/gs4.png|http://doc.qt.nokia.com/4.7/images/gs4.png]]
<br />Revisemos la nueva definición de la clase Bloc de Notas (Notepad)
<br /><code>#include &lt;QtGui&amp;gt;
<br />class Notepad : public QMainWindow<br />{<br /> Q_OBJECT
<br />public:<br /> Notepad();
<br /> private slots:<br /> void open();<br /> void save();<br /> void quit();
<br /> private:<br /> QTextEdit *textEdit;
<br /> QAction *openAction;<br /> QAction *saveAction;<br /> QAction *exitAction;
<br /> QMenu *fileMenu;<br />};</code>
<br />Incluimos dos '''slots''' más que pueden guardar y abrir un documento. Implementaremos su funcionalidad en la siguiente sección.
<br />A menudo, en una ventana principal (main window), el mismo '''slot''' debe ser invocado por varios widgets. Ejemplos de ello son los elementos de menú y los botones en una barra de herramientas. Para hacer esto más fácil, Qt proporciona &quot;QAction&amp;quot;:http://doc.qt.nokia.com/4.7/qaction.html, que puede ser dada a varios widgets, y ser conectada a un slot. Por ejemplo, tanto &quot;QMenu&amp;quot;:http://doc.qt.nokia.com/4.7/qmenu.html como &quot;QToolBar&amp;quot;:http://doc.qt.nokia.com/4.7/qtoolbar.html pueden crear elementos de menú y botones de herramientas de las mismas &quot;QAction&amp;quot;:http://doc.qt.nokia.com/4.7/qaction.htmls. En breve vamos a ver como funciona esto.
<br />Como antes, usamos el constructor del Bloc de Notas (Notepad) para configurar la GUI.
<br /><code>Notepad::Notepad()<br />{<br /> saveAction = new QAction(tr(&quot;&amp;Open&amp;quot;), this);<br /> saveAction = new QAction(tr(&quot;&amp;Save&amp;quot;), this);<br /> exitAction = new QAction(tr(&quot;E&amp;amp;xit&amp;quot;), this);
<br /> connect(openAction, SIGNAL (triggered()), this, SLOT (open()));<br /> connect(saveAction, SIGNAL (triggered()), this, SLOT (save()));<br /> connect(exitAction, SIGNAL (triggered()), qApp, SLOT (quit()));
<br /> fileMenu = menuBar()</s>&gt;addMenu(tr(&quot;&amp;File&amp;quot;));<br /> fileMenu-&gt;addAction(openAction);<br /> fileMenu-&gt;addAction(saveAction);<br /> fileMenu-&gt;addSeparator();<br /> fileMenu-&gt;addAction(exitAction);


* Main windows y clases main window – [http://doc.qt.nokia.com/4.7/mainwindow.html Aplicación Main Window] ''[doc.qt.nokia.com]'', [http://doc.qt.nokia.com/4.7/examples-mainwindow.html Ejemplos Main Window] ''[doc.qt.nokia.com]''
textEdit = new QTextEdit;<br /> setCentralWidget(textEdit);
* Aplicaciones <span class="caps">MDI</span> – [http://doc.qt.nokia.com/4.7/qmdiarea.html QMdiArea] ''[doc.qt.nokia.com]'', [http://doc.qt.nokia.com/4.7/mainwindows-mdi.html Ejemplo <span class="caps">MDI</span>] ''[doc.qt.nokia.com]''


==Guardando y Cargando==
setWindowTitle(tr(&quot;Notepad&amp;quot;));<br />}</code>


En este ejemplo, vamos a implementar la funcionalidad de los '''slots open()''' y '''save()''' que adicionamos en el ejemplo anterior.
Las &quot;QAction&amp;quot;:http://doc.qt.nokia.com/4.7/qaction.htmls son creadas con el texto que debe aparecer en los widgets a los que las adicionemos (en nuestro caso, los elementos de menú). Si también quisieramos añadirlos a una barra de herramientas, podríamos haberles dado &quot;iconos&amp;quot;:http://doc.qt.nokia.com/4.7/qaction.html a las acciones (actions).


[[Image:gs5.png]]
Cuando un elemento de menú es presionado, el elemento dispara la accion, y el respectivo slot se invocará.


Vamos a iniciar con el '''slot open()''':
=== Aprender Más ===


El primer paso es preguntar al usuario por el nombre del archivo a abrir. Qt viene con [http://doc.qt.nokia.com/4.7/qfiledialog.html QFileDialog] ''[doc.qt.nokia.com]'', éste es un dialogo con el cual el usuario puede seleccionar un archivo. La siguiente imagen muestra el dialogo en Kubuntu. La funcion estática (static) [http://doc.qt.nokia.com/4.7/qfiledialog.html#getOpenFileName getOpenFileName()] ''[doc.qt.nokia.com]'' muestra un dialogo de archivos modales, y no retorna hasta que el usuario ha seleccionado un archivo. Éste retorna la ruta del archivo seleccionado, o una cadena de texto (string) vacía si el usuario cancela el diálogo.
* Main windows y clases main window - &quot;Aplicación Main Window&amp;quot;:http://doc.qt.nokia.com/4.7/mainwindow.html, &quot;Ejemplos Main Window&amp;quot;:http://doc.qt.nokia.com/4.7/examples-mainwindow.html
* Aplicaciones MDI - &quot;QMdiArea&amp;quot;:http://doc.qt.nokia.com/4.7/qmdiarea.html, &quot;Ejemplo MDI&amp;quot;:http://doc.qt.nokia.com/4.7/mainwindows-mdi.html


Si tenemos un nombre de archivo, tratamos de abrirlo con [http://doc.qt.nokia.com/4.7/qiodevice.html#open open()] ''[doc.qt.nokia.com]'', que devuelve verdadero (true) si el archivo se puede abrir. No vamos a entrar en el manejo de errores aquí, pero puede consultar los enlaces de la sección de aprender más. Si el archivo no se puede abrir, utilizamos [http://doc.qt.nokia.com/4.7/qmessagebox.html QMessageBox] ''[doc.qt.nokia.com]'' para mostrar un diálogo con un mensaje de error (consulte la descripción de la clase [http://doc.qt.nokia.com/4.7/qmessagebox.html QMessageBox] ''[doc.qt.nokia.com]'' para más detalles).
== Guardando y Cargando ==


En realidad, la lectura de los datos es trivial utilizando la función [http://doc.qt.nokia.com/4.7/qiodevice.html#readAll readAll()] ''[doc.qt.nokia.com]'', la cual devuelve todos los datos del archivo en un [http://doc.qt.nokia.com/4.7/qbytearray.html QByteArray] ''[doc.qt.nokia.com]''. La función [http://doc.qt.nokia.com/4.7/qbytearray.html#constData constData()] ''[doc.qt.nokia.com]'' devuelve todos los datos del arreglo (array) como un const char *, [http://doc.qt.nokia.com/4.7/qstring.html QString] ''[doc.qt.nokia.com]'' tiene un constructor para éste. Los contenidos se pueden visualizar en el editor de texto. Luego llamamos la función [http://doc.qt.nokia.com/4.7/qiodevice.html#close close()] ''[doc.qt.nokia.com]'' que cierra el archivo para retornar la descripción del archivo al sistema operativo.
En este ejemplo, vamos a implementar la funcionalidad de los '''slots open()''' y '''save()''' que adicionamos en el ejemplo anterior.


Ahora, vamos a pasar al slot save().
[[Image:http://doc.qt.nokia.com/4.7/images/gs5.png|http://doc.qt.nokia.com/4.7/images/gs5.png]]


Cuando escribimos el contenido del editor de texto en el archivo, utillizamos la clase [http://doc.qt.nokia.com/4.7/qtextstream.html QTextStream] ''[doc.qt.nokia.com]'', que envuelve al objeto [http://doc.qt.nokia.com/4.7/qfile.html QFile] ''[doc.qt.nokia.com]''. El flujo de texto puede escribir QStrings directamente al archivo; [http://doc.qt.nokia.com/4.7/qfile.html QFile] ''[doc.qt.nokia.com]'' sólo acepta los datos en bruto (char *) con las funciones [http://doc.qt.nokia.com/4.7/qiodevice.html#write write()] ''[doc.qt.nokia.com]'' de [http://doc.qt.nokia.com/4.7/qiodevice.html <span class="caps">QIOD</span>evice] ''[doc.qt.nokia.com]''.
Vamos a iniciar con el '''slot open()''':


===Aprender Más===
<code>QString fileName = QFileDialog::getOpenFileName(this, tr(&quot;Open File&amp;quot;), &quot;&quot;,<br /> tr(&quot;Text Files ('''.txt);;C++ Files ('''.cpp '''.h)&quot;));
<br />if (fileName != &quot;&quot;) {<br /> QFile file&amp;amp;#40;fileName&amp;amp;#41;;<br /> if (!file.open(QIODevice::ReadOnly)) {<br /> QMessageBox::critical(this, tr(&quot;Error&amp;quot;),<br /> tr(&quot;Could not open file&amp;quot;));<br /> return;<br /> }<br /> QString contents = file.readAll().constData();<br /> textEdit-&gt;setPlainText(contents);<br /> file.close();<br />}</code>
<br />El primer paso es preguntar al usuario por el nombre del archivo a abrir. Qt viene con &quot;QFileDialog&amp;quot;:http://doc.qt.nokia.com/4.7/qfiledialog.html, éste es un dialogo con el cual el usuario puede seleccionar un archivo. La siguiente imagen muestra el dialogo en Kubuntu. La funcion estática (static) &quot;getOpenFileName()&quot;:http://doc.qt.nokia.com/4.7/qfiledialog.html#getOpenFileName muestra un dialogo de archivos modales, y no retorna hasta que el usuario ha seleccionado un archivo. Éste retorna la ruta del archivo seleccionado, o una cadena de texto (string) vacía si el usuario cancela el diálogo.
<br />Si tenemos un nombre de archivo, tratamos de abrirlo con &quot;open()&quot;:http://doc.qt.nokia.com/4.7/qiodevice.html#open, que devuelve verdadero (true) si el archivo se puede abrir. No vamos a entrar en el manejo de errores aquí, pero puede consultar los enlaces de la sección de aprender más. Si el archivo no se puede abrir, utilizamos &quot;QMessageBox&amp;quot;:http://doc.qt.nokia.com/4.7/qmessagebox.html para mostrar un diálogo con un mensaje de error (consulte la descripción de la clase &quot;QMessageBox&amp;quot;:http://doc.qt.nokia.com/4.7/qmessagebox.html para más detalles).
<br />En realidad, la lectura de los datos es trivial utilizando la función &quot;readAll()&quot;:http://doc.qt.nokia.com/4.7/qiodevice.html#readAll, la cual devuelve todos los datos del archivo en un &quot;QByteArray&amp;quot;:http://doc.qt.nokia.com/4.7/qbytearray.html. La función &quot;constData()&quot;:http://doc.qt.nokia.com/4.7/qbytearray.html#constData devuelve todos los datos del arreglo (array) como un const char''', &quot;QString&amp;quot;:http://doc.qt.nokia.com/4.7/qstring.html tiene un constructor para éste. Los contenidos se pueden visualizar en el editor de texto. Luego llamamos la función &quot;close()&quot;:http://doc.qt.nokia.com/4.7/qiodevice.html#close que cierra el archivo para retornar la descripción del archivo al sistema operativo.


* Archivos y dispositivos de E/S – [http://doc.qt.nokia.com/4.7/qfile.html QFile] ''[doc.qt.nokia.com]'', [http://doc.qt.nokia.com/4.7/qiodevice.html <span class="caps">QIOD</span>evice] ''[doc.qt.nokia.com]''
Ahora, vamos a pasar al slot save().


===Categories:===
<code>QString fileName = QFileDialog::getSaveFileName(this, tr(&quot;Save File&amp;quot;), &quot;&quot;,<br /> tr(&quot;Text Files ('''.txt);;C++ Files ('''.cpp '''.h)&quot;));
<br />if (fileName != &quot;&quot;) {<br /> QFile file&amp;amp;#40;fileName&amp;amp;#41;;<br /> if (!file.open(QIODevice::WriteOnly)) {<br /> // error message<br /> } else {<br /> QTextStream stream(&amp;file);<br /> stream &lt;&lt; textEdit-&gt;toPlainText();<br /> stream.flush();<br /> file.close();<br /> }<br />}</code>
<br />Cuando escribimos el contenido del editor de texto en el archivo, utillizamos la clase &quot;QTextStream&amp;quot;:http://doc.qt.nokia.com/4.7/qtextstream.html, que envuelve al objeto &quot;QFile&amp;quot;:http://doc.qt.nokia.com/4.7/qfile.html. El flujo de texto puede escribir QStrings directamente al archivo; &quot;QFile&amp;quot;:http://doc.qt.nokia.com/4.7/qfile.html sólo acepta los datos en bruto (char''') con las funciones &quot;write()&quot;:http://doc.qt.nokia.com/4.7/qiodevice.html#write de &quot;QIODevice&amp;quot;:http://doc.qt.nokia.com/4.7/qiodevice.html.


* [[:Category:Learning|Learning]]
=== Aprender Más ===
* [[:Category:Spanish|Spanish]]

Revision as of 09:03, 24 February 2015


Introducción a la Programación con Qt

Bienvenido al mundo de Qt, la herramienta multiplataforma para GUI (interfaz gráficas de usuario). En esta guía de introducción, aprenderemos temas básicos de Qt mediante la implementación de una simple aplicación Notepad (Bloc de Notas). Al terminar de leer esta guía, usted debería estar listo para ahondar en nuestras descripciones tecnológicas generales y en la documentación del API, para poder encontrar la información que necesite sobre la aplicación que esté desarrollando.

Hola Bloc de Notas

En este primer ejemplo, simplemente creamos y mostramos en el escritorio, un editor de texto dentro de un marco de ventana. Esto representa el programa más simple posible de Qt que posea GUI.

http://doc.qt.nokia.com/4.7/images/gs1.png

Este es el código:

#include &lt;QApplication&amp;gt;<br />#include &lt;QTextEdit&amp;gt;

int main(int argv, char **args)<br />{<br /> QApplication app(argv, args);

QTextEdit textEdit;<br /> textEdit.show();

return app.exec&amp;amp;#40;&amp;#41;;<br />}

Revisemos el código línea por línea. En las primeras dos líneas, incluimos los archivos de cabecera de "QApplication&quot;:http://doc.qt.nokia.com/4.7/qapplication.html y "QTextEdit&quot;:http://doc.qt.nokia.com/4.7/qtextedit.html, las cuales son las dos clases que necesitamos para este ejemplo. Todas las clases de Qt tienen un archivo de cabecera que lleva su nombre.

En la línea 6 creamos un objeto de la clase "QApplication&quot;:http://doc.qt.nokia.com/4.7/qapplication.html. Este objeto administra los recursos de la aplicación y es necesario para ejecutar cualquier programa de Qt que tenga GUI. Necesita argv y argc debido a que Qt acepta algunos argumentos de la línea de comandos.

En la línea 8 creamos un objeto de la clase "QTextEdit&quot;:http://doc.qt.nokia.com/4.7/qtextedit.html. Un editor de texto es un elemento visual en la interfaz gráfica. En Qt, estos elementos se conocen con el nombre de widgets. Otros ejemplos de widgets son: barras de desplazamiento, etiquetas, y botones de radio. Un widget también puede ser un contenedor para otros widgets; un diálogo o la ventana principal de una aplicación, por ejemplo.

En la línea 9 mostramos el editor de texto en la pantalla en su propio marco de ventana. Debido a que los widgets también funcionan como contenedores (por ejemplo una "QMainWindow&quot;:http://doc.qt.nokia.com/4.7/qmainwindow.html, la cual tiene barras de herramientas, menús, una barra de estatus, y algunos otros widgets), es posible mostrar un solo widget en su propia ventana. Los widgets no son visibles por defecto, la función show() hace visibles los widgets.

En la línea 11 la "QApplication&quot;:http://doc.qt.nokia.com/4.7/qapplication.html entra en su ciclo de eventos. Cuando una aplicación de Qt se está ejecutando, los eventos son generados y enviados a los widgets de la aplicación. Algunos ejemplos de eventos son presionar algún botón del mouse y pulsar alguna tecla. Cuando usted escribe texto en el widget editor de texto, este recibe eventos de tecla presionada y responde dibujando el texto tecleado.

Para ejecutar la aplicación, ejecute una terminal o símbolo del sistema en (Windows), y entre al directorio en el cual tiene el archivo .cpp del programa. Los siguientes comandos de shell construyen el programa.

<br />qmake <s>project<br />qmake<br /> make<br />


Esto generará un ejecutable en el directorio part1 (note que en Windows, posiblemente tenga que utilizar nmake en lugar de make. Note, que el ejecutable estará localizado en part1/debug o part1/release).
Qmake es la herramienta de construcción de proyectos de Qt, el cual, utiliza un archivo de configuración. Qmake genera este archivo por nosotros cuando le enviamos el argumento project*. Dado el archivo de configuración (con el sufijo .pro), qmake produce un archivo make el cual, construirá el programa por usted. Más adelante veremos como escribir nuestros propios archivos .pro
h3. Aprender Más
* Widgets y Geometría de Ventanas
"Widgets Diálogo y Ventana&quot;:http://doc.qt.nokia.com/4.7/application-windows.html
Eventos y manejo de eventos "El Sistema de Eventos&quot;:http://doc.qt.nokia.com/4.7/eventsandfilters.html

Agregando un botón Salir (Quit)

En una aplicación real, normalmente necesitará más de un widget. Vamos ahora a agregar un "QPushButton&quot;:http://doc.qt.nokia.com/4.7/qpushbutton.html debajo del editor de texto. El botón hará que la aplicación Bloc de Notas finalice cuando sea presionado (ejemplo, se da click con el mouse).

http://doc.qt.nokia.com/4.7/images/gs2.png

Revisemos el código.

<br />#include &lt;QtGui&amp;gt;

int main(int argv, char **args)<br />{<br /> QApplication app(argv, args);

QWidget window;

QTextEdit *textEdit = new QTextEdit(&amp;window);<br /> QPushButton *quitButton = new QPushButton(&quot;Quit&amp;quot;);

QObject::connect(quitButton, SIGNAL (clicked()), qApp, SLOT (quit()));

QVBoxLayout layout;<br /> layout.addWidget(textEdit);<br /> layout.addWidget(quitButton);

window.setLayout(&amp;layout);

window.show();

return app.exec&amp;amp;#40;&amp;#41;;<br />}<br />

La línea 1 incluye el archivo de cabecera "QtGui&quot;:http://doc.qt.nokia.com/4.7/qtgui.html, el cual contiene todas las clases de GUI de Qt.

La línea 10 utiliza el mecanismo de Signals y Slots de Qt para hacer que la aplicación termine cuando el botón Quit sea presionado. Un slot es una función que puede ser invocada en tiempo de ejecución utilizando su nombre (como una cadena de caracteres literal). Una signal es una función que invoca a los slots registrados con ella, cuando es llamada; Invocamos eso para conectar el slot con la signal y emitir la signal.

"quit()":http://doc.qt.nokia.com/4.7/qcoreapplication.html#quit es un slot de "QApplication&quot;:http://doc.qt.nokia.com/4.7/qapplication.html que termina la aplicación. "clicked()":http://doc.qt.nokia.com/4.7/qabstractbutton.html#clicked es una signal que "QPushButton&quot;:http://doc.qt.nokia.com/4.7/qpushbutton.html emite cuando es presionado. La función estática "QObject::connect()":http://doc.qt.nokia.com/4.7/qobject.html#connect se encarga de conectar el slot a la signal. SIGNAL&amp;#40;&#41; y SLOT&amp;#40;&#41; son dos macros que reciben la firma de las funciones signal y slot a conectar. También necesitamos enviar apuntadores a los objetos que deben enviar y recibir la señal.

En la línea 12 creamos un "QVBoxLayout&quot;:http://doc.qt.nokia.com/4.7/qvboxlayout.html. Como mencionamos, los widgets pueden contener otros widgets. Es posible establecer los límites (la localización y el tamaño) de los widgets hijos directamente, pero usualmente es más sencillo utilizar un layout. Un layout administra los límites de los widgets hijos. "QVBoxLayout&quot;:http://doc.qt.nokia.com/4.7/qvboxlayout.html, por ejemplo, coloca los hijos en una fila vertical.

Las líneas 13 y 14 agregan el editor de texto y el botón al layout. En la línea 17, establecemos el layout sobre el widget.

Aprender Más

Crear Una Subclase de QWidget

Cuando el usuario quiere salir de una aplicación, es muy normal mostrar un diálogo que le pregunte sobre si de verdad desea salir. En este ejemplo, crearemos una subclase de QWidget, y agregaremos un slot que conectaremos al botón Quit.

http://doc.qt.nokia.com/4.7/images/gs3.png

Revisemos el código:

class Notepad : public QWidget<br />{<br /> Q_OBJECT

public:<br /> Notepad();

private slots:<br /> void quit();

private:<br /> QTextEdit *textEdit;<br /> QPushButton *quitButton;<br />};

La macro Q_OBJECT debe estar primero en la definición de la clase, y declara nuestra clase como un QObject (Naturalmente, también debe de heredar de "QObject&quot;:http://doc.qt.nokia.com/4.7/qobject.html). Un "QObject&quot;:http://doc.qt.nokia.com/4.7/qobject.html añade varias capacidades a una clase normal de C++. Notablemente, el nombre de la clase y los nombres de los slots pueden ser consultados en tiempo de ejecución. También es posible consultar el tipo de los parámetros de un slot e invocarlo.

La línea 13 declara el slot quit(). Esto es sencillo utilizando la marco slots. El slot quit() ahora puede conectarse a las signals que coincidan en su firma (cualquier signal que no reciba parámetros).

En lugar de configurar la interfaz gráfica y conectar el slot en la función main(), ahora utilizamos el constructor del Bloc de Notas.

Notepad::Notepad()<br />{<br /> textEdit = new QTextEdit;<br /> quitButton = new QPushButton(tr(&quot;Quit&amp;quot;));

connect(quitButton, SIGNAL (clicked()), this, SLOT (quit()));

QVBoxLayout '''layout = new QVBoxLayout;<br /> layout-&gt;addWidget(textEdit);<br /> layout-&gt;addWidget(quitButton);
<br /> setLayout(layout);
<br /> setWindowTitle(tr(&quot;Notepad&amp;quot;));<br />}


Como se puede ver en la definición de la clase, utilizamos apuntadores (punteros) a nuestros "QObject&quot;:http://doc.qt.nokia.com/4.7/qobject.htmls (textEdit y quitButton) Como regla, usted siempre debe reservar memoria para "QObject&quot;:http://doc.qt.nokia.com/4.7/qobject.htmls en el heap y nunca copiarlos.
Ahora utilizamos la función "tr()":http://doc.qt.nokia.com/4.7/qobject.html#tr alrededor de las cadenas de texto que serán visibles por el usuario. Esta función es necesaria cuando usted desea proveer su aplicación en más de un lenguaje (ejemplo, Inglés y Chino) No entraremos en detalles aquí, pero puede consultar el enlace Qt Linguist de la tabla de aprenda más.
h3. Aprender Más
tr() e internacionalización - "Manual Qt Linguist&quot;:http://doc.qt.nokia.com/4.7/linguist-manual.html, "Escribiendo Código Fuente Para Traducción&quot;:http://doc.qt.nokia.com/4.7/i18n-source-translation.html, "Ejemplo Hola tr()":http://doc.qt.nokia.com/4.7/linguist-hellotr.html, "Internacionalización con Qt&quot;:http://doc.qt.nokia.com/4.7/internationalization.html
* "QObjects&quot;:http://doc.qt.nokia.com/4.7/qtwebkit-bridge.html#qobjects y el Modelo de Objetos de Qt (Esto es esencial para entender Qt) - "Modelo de Objetos&quot;:http://doc.qt.nokia.com/4.7/object.html
* qmake y el sistema de construcción de Qt - "Manual qmake&quot;:http://doc.qt.nokia.com/4.7/qmake-manual.html

Creando un archivo .pro

Para este ejemplo escribiremos nuestro archivo en lugar de utilizar la opción de qmake project


<br />HEADERS = notepad.h<br />SOURCES = notepad.cpp main.cpp<br />


Los siguientes comandos de shell construyen el ejemplo

<br />qmake<br />make<br />


h2. Usando una QMainWindow
Muchas aplicaciones se beneficiarán del uso de un "QMainWindow&quot;:http://doc.qt.nokia.com/4.7/qmainwindow.html, la cual tiene su propio layout al cual puede agregar una barra de menús, widgets de acoplamiento (dock widgets), barras de herramientas, y una barra de estado. "QMainWindow&quot;:http://doc.qt.nokia.com/4.7/qmainwindow.html tiene un área central que puede ser ocupada por cualquier tipo de widget. En nuestro caso, vamos a ubicar nuestro editor de texto aquí.
http://doc.qt.nokia.com/4.7/images/gs4.png
Revisemos la nueva definición de la clase Bloc de Notas (Notepad)


#include &lt;QtGui&amp;gt;
<br />class Notepad : public QMainWindow<br />{<br /> Q_OBJECT
<br />public:<br /> Notepad();
<br /> private slots:<br /> void open();<br /> void save();<br /> void quit();
<br /> private:<br /> QTextEdit *textEdit;
<br /> QAction *openAction;<br /> QAction *saveAction;<br /> QAction *exitAction;
<br /> QMenu *fileMenu;<br />};


Incluimos dos slots más que pueden guardar y abrir un documento. Implementaremos su funcionalidad en la siguiente sección.
A menudo, en una ventana principal (main window), el mismo slot debe ser invocado por varios widgets. Ejemplos de ello son los elementos de menú y los botones en una barra de herramientas. Para hacer esto más fácil, Qt proporciona "QAction&quot;:http://doc.qt.nokia.com/4.7/qaction.html, que puede ser dada a varios widgets, y ser conectada a un slot. Por ejemplo, tanto "QMenu&quot;:http://doc.qt.nokia.com/4.7/qmenu.html como "QToolBar&quot;:http://doc.qt.nokia.com/4.7/qtoolbar.html pueden crear elementos de menú y botones de herramientas de las mismas "QAction&quot;:http://doc.qt.nokia.com/4.7/qaction.htmls. En breve vamos a ver como funciona esto.
Como antes, usamos el constructor del Bloc de Notas (Notepad) para configurar la GUI.


Notepad::Notepad()<br />{<br /> saveAction = new QAction(tr(&quot;&amp;Open&amp;quot;), this);<br /> saveAction = new QAction(tr(&quot;&amp;Save&amp;quot;), this);<br /> exitAction = new QAction(tr(&quot;E&amp;amp;xit&amp;quot;), this);
<br /> connect(openAction, SIGNAL (triggered()), this, SLOT (open()));<br /> connect(saveAction, SIGNAL (triggered()), this, SLOT (save()));<br /> connect(exitAction, SIGNAL (triggered()), qApp, SLOT (quit()));
<br /> fileMenu = menuBar()</s>&gt;addMenu(tr(&quot;&amp;File&amp;quot;));<br /> fileMenu-&gt;addAction(openAction);<br /> fileMenu-&gt;addAction(saveAction);<br /> fileMenu-&gt;addSeparator();<br /> fileMenu-&gt;addAction(exitAction);

textEdit = new QTextEdit;<br /> setCentralWidget(textEdit);

setWindowTitle(tr(&quot;Notepad&amp;quot;));<br />}

Las "QAction&quot;:http://doc.qt.nokia.com/4.7/qaction.htmls son creadas con el texto que debe aparecer en los widgets a los que las adicionemos (en nuestro caso, los elementos de menú). Si también quisieramos añadirlos a una barra de herramientas, podríamos haberles dado "iconos&quot;:http://doc.qt.nokia.com/4.7/qaction.html a las acciones (actions).

Cuando un elemento de menú es presionado, el elemento dispara la accion, y el respectivo slot se invocará.

Aprender Más

Guardando y Cargando

En este ejemplo, vamos a implementar la funcionalidad de los slots open() y save() que adicionamos en el ejemplo anterior.

http://doc.qt.nokia.com/4.7/images/gs5.png

Vamos a iniciar con el slot open():

QString fileName = QFileDialog::getOpenFileName(this, tr(&quot;Open File&amp;quot;), &quot;&quot;,<br /> tr(&quot;Text Files ('''.txt);;C++ Files ('''.cpp '''.h)&quot;));
<br />if (fileName != &quot;&quot;) {<br /> QFile file&amp;amp;#40;fileName&amp;amp;#41;;<br /> if (!file.open(QIODevice::ReadOnly)) {<br /> QMessageBox::critical(this, tr(&quot;Error&amp;quot;),<br /> tr(&quot;Could not open file&amp;quot;));<br /> return;<br /> }<br /> QString contents = file.readAll().constData();<br /> textEdit-&gt;setPlainText(contents);<br /> file.close();<br />}


El primer paso es preguntar al usuario por el nombre del archivo a abrir. Qt viene con "QFileDialog&quot;:http://doc.qt.nokia.com/4.7/qfiledialog.html, éste es un dialogo con el cual el usuario puede seleccionar un archivo. La siguiente imagen muestra el dialogo en Kubuntu. La funcion estática (static) "getOpenFileName()":http://doc.qt.nokia.com/4.7/qfiledialog.html#getOpenFileName muestra un dialogo de archivos modales, y no retorna hasta que el usuario ha seleccionado un archivo. Éste retorna la ruta del archivo seleccionado, o una cadena de texto (string) vacía si el usuario cancela el diálogo.
Si tenemos un nombre de archivo, tratamos de abrirlo con "open()":http://doc.qt.nokia.com/4.7/qiodevice.html#open, que devuelve verdadero (true) si el archivo se puede abrir. No vamos a entrar en el manejo de errores aquí, pero puede consultar los enlaces de la sección de aprender más. Si el archivo no se puede abrir, utilizamos "QMessageBox&quot;:http://doc.qt.nokia.com/4.7/qmessagebox.html para mostrar un diálogo con un mensaje de error (consulte la descripción de la clase "QMessageBox&quot;:http://doc.qt.nokia.com/4.7/qmessagebox.html para más detalles).
En realidad, la lectura de los datos es trivial utilizando la función "readAll()":http://doc.qt.nokia.com/4.7/qiodevice.html#readAll, la cual devuelve todos los datos del archivo en un "QByteArray&quot;:http://doc.qt.nokia.com/4.7/qbytearray.html. La función "constData()":http://doc.qt.nokia.com/4.7/qbytearray.html#constData devuelve todos los datos del arreglo (array) como un const char, "QString&quot;:http://doc.qt.nokia.com/4.7/qstring.html tiene un constructor para éste. Los contenidos se pueden visualizar en el editor de texto. Luego llamamos la función "close()":http://doc.qt.nokia.com/4.7/qiodevice.html#close que cierra el archivo para retornar la descripción del archivo al sistema operativo.

Ahora, vamos a pasar al slot save().

QString fileName = QFileDialog::getSaveFileName(this, tr(&quot;Save File&amp;quot;), &quot;&quot;,<br /> tr(&quot;Text Files ('''.txt);;C++ Files ('''.cpp '''.h)&quot;));
<br />if (fileName != &quot;&quot;) {<br /> QFile file&amp;amp;#40;fileName&amp;amp;#41;;<br /> if (!file.open(QIODevice::WriteOnly)) {<br /> // error message<br /> } else {<br /> QTextStream stream(&amp;file);<br /> stream &lt;&lt; textEdit-&gt;toPlainText();<br /> stream.flush();<br /> file.close();<br /> }<br />}


Cuando escribimos el contenido del editor de texto en el archivo, utillizamos la clase "QTextStream&quot;:http://doc.qt.nokia.com/4.7/qtextstream.html, que envuelve al objeto "QFile&quot;:http://doc.qt.nokia.com/4.7/qfile.html. El flujo de texto puede escribir QStrings directamente al archivo; "QFile&quot;:http://doc.qt.nokia.com/4.7/qfile.html sólo acepta los datos en bruto (char) con las funciones "write()":http://doc.qt.nokia.com/4.7/qiodevice.html#write de "QIODevice&quot;:http://doc.qt.nokia.com/4.7/qiodevice.html.

Aprender Más