summaryrefslogtreecommitdiff
path: root/NxWidgets/nxwm/include/ctaskbar.hxx
diff options
context:
space:
mode:
authorpatacongo <patacongo@42af7a65-404d-4744-a932-0658087f49c3>2012-04-30 01:21:26 +0000
committerpatacongo <patacongo@42af7a65-404d-4744-a932-0658087f49c3>2012-04-30 01:21:26 +0000
commit284cd6923b521898c0927992fab77593ad797b4a (patch)
treeecdc27cff477efee7da31d0fae65b527377e094f /NxWidgets/nxwm/include/ctaskbar.hxx
parent45f021f2a88d9f76c7802aa31d3fc67827ff288d (diff)
downloadnuttx-284cd6923b521898c0927992fab77593ad797b4a.tar.gz
nuttx-284cd6923b521898c0927992fab77593ad797b4a.tar.bz2
nuttx-284cd6923b521898c0927992fab77593ad797b4a.zip
NxWM update
git-svn-id: svn://svn.code.sf.net/p/nuttx/code/trunk@4677 42af7a65-404d-4744-a932-0658087f49c3
Diffstat (limited to 'NxWidgets/nxwm/include/ctaskbar.hxx')
-rw-r--r--NxWidgets/nxwm/include/ctaskbar.hxx238
1 files changed, 238 insertions, 0 deletions
diff --git a/NxWidgets/nxwm/include/ctaskbar.hxx b/NxWidgets/nxwm/include/ctaskbar.hxx
new file mode 100644
index 000000000..0c420a0e2
--- /dev/null
+++ b/NxWidgets/nxwm/include/ctaskbar.hxx
@@ -0,0 +1,238 @@
+/****************************************************************************
+ * NxWidgets/nxwm/include/cnxtaskbar.hxx
+ *
+ * Copyright (C) 2012 Gregory Nutt. All rights reserved.
+ * Author: Gregory Nutt <gnutt@nuttx.org>
+ *
+ * Redistribution and use in source and binary forms, with or without
+ * modification, are permitted provided that the following conditions
+ * are met:
+ *
+ * 1. Redistributions of source code must retain the above copyright
+ * notice, this list of conditions and the following disclaimer.
+ * 2. Redistributions in binary form must reproduce the above copyright
+ * notice, this list of conditions and the following disclaimer in
+ * the documentation and/or other materials provided with the
+ * distribution.
+ * 3. Neither the name NuttX, NxWidgets, nor the names of its contributors
+ * me be used to endorse or promote products derived from this software
+ * without specific prior written permission.
+ *
+ * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
+ * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
+ * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
+ * FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
+ * COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
+ * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
+ * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS
+ * OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED
+ * AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
+ * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN
+ * ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
+ * POSSIBILITY OF SUCH DAMAGE.
+ *
+ ****************************************************************************/
+
+#ifndef __NXWM_INCLUDE_CTASKBAR_HXX
+#define __NXWM_INCLUDE_CTASKBAR_HXX
+
+/****************************************************************************
+ * Included Files
+ ****************************************************************************/
+
+#include <nuttx/config.h>
+
+#include "nxconfig.hxx"
+#include "tnxarray.hxx"
+#include "inxwindow.hxx"
+#include "cnxserver.hxx"
+#include "cwidgeteventhandler.hxx"
+#include "cwidgeteventargs.hxx"
+
+#include "iapplication.hxx"
+
+/****************************************************************************
+ * Pre-processor Definitions
+ ****************************************************************************/
+
+/****************************************************************************
+ * Implementation Class Definition
+ ****************************************************************************/
+
+#if defined(__cplusplus)
+
+namespace NxWM
+{
+ /**
+ * This class describes the NX window manager's task bar
+ */
+
+ class CTaskbar : public NXWidgets::CNxServer, private NXWidgets::CWidgetEventHandler
+ {
+ private:
+ NXWidgets::INxWindow *m_taskbar; /**< The toolbar window */
+ NXWidgets::INxWindow *m_background; /**< The background window */
+ TNxArray<IApplication*> m_applications; /**< List of apps in the task bar */
+
+ /**
+ * Connect to the server
+ */
+
+ bool connect(void);
+
+ /**
+ * Disconnect from the server
+ */
+
+ void disconnect(void);
+
+ /**
+ * Create a raw window.
+ *
+ * 1) Create a dumb CWigetControl instance
+ * 2) Pass the dumb CWidgetControl instance to the window constructor
+ * that inherits from INxWindow. This will "smarten" the CWidgetControl
+ * instance with some window knowlede
+ * 3) Call the open() method on the window to display the window.
+ * 4) After that, the fully smartened CWidgetControl instance can
+ * be used to generate additional widgets by passing it to the
+ * widget constructor
+ */
+
+ NXWidgets::CNxWindow *openRawWindow(void);
+
+ /**
+ * Create a framed application window
+ *
+ * This may be used to provide the window parater to the IApplication constructor
+ *
+ * @return A partially initialized application window instance.
+ */
+
+ NXWidgets::CNxTkWindow *openFramedWindow(void);
+
+ /**
+ * Set size and position of a window in the application area.
+ *
+ * @param window. The window to be resized and repositioned
+ */
+
+ void setApplicationGeometry(NXWidgets::INxWindow *window);
+
+ /**
+ * Create the toolbar window.
+ *
+ * @return true on success
+ */
+
+ bool createToolbarWindow(void);
+
+ /**
+ * Create the background window.
+ *
+ * @return true on success
+ */
+
+ bool createBackgroundWindow(void);
+
+
+ /**
+ * Handle a mouse button click event.
+ *
+ * @param e The event data.
+ */
+
+ void handleClickEvent(const NXWidgets::CWidgetEventArgs &e);
+
+ /**
+ * CTaskbar Destructor
+ */
+
+ ~CTaskbar(void);
+
+ public:
+ /**
+ * CTaskbar Constructor
+ *
+ * @param hWnd - NX server handle
+ */
+
+ CTaskbar(void);
+
+ /**
+ * Start the window manager and present the initial displays. The window
+ * manager start-up sequence is:
+ *
+ * 1. Create the CTaskbar instance,
+ * 2. Call CTaskBar::startApplication repeatedly to add applications to the task bar
+ * 3. Call CTaskBar::startWindowManager to start the display with applications in place
+ *
+ * startWindowManager will present the taskar and the background image. The
+ * initial taskbar will contain only the start window icon.
+ */
+
+ bool startWindowManager(void);
+
+ /**
+ * Create an application window. Creating a new application in the start
+ * window requires three steps:
+ *
+ * 1. Call CTaskBar::openApplicationWindow to create a window for the application,
+ * 2. Instantiate the application, providing the window to the application's
+ * constructor,
+ * 3. Then call CStartWindow::addApplication to add the application to the
+ * start window.
+ *
+ * When the application is selected from the start window:
+ *
+ * 4. Call CTaskBar::startApplication start the application and bring its window to
+ * the top.
+ */
+
+ CApplicationWindow *openApplicationWindow(void);
+
+ /**
+ * Start an application and add its icon to the taskbar. The applications's
+ * window is brought to the top. Creating a new application in the start
+ * window requires three steps:
+ *
+ * 1. Call CTaskBar::openApplicationWindow to create a window for the application,
+ * 2. Instantiate the application, providing the window to the application's
+ * constructor,
+ * 3. Then call CStartWindow::addApplication to add the application to the start window.
+ *
+ * When the application is selected from the start window:
+ *
+ * 4. Call CTaskBar::startApplication start the application and bring its window to
+ * the top.
+ *
+ * @param app. The new application to add to the task bar
+ * @param minimized. The new application starts in the minimized state
+ * @return true on success
+ */
+
+ bool startApplication(IApplication *app, bool minimized);
+
+ /**
+ * Hide an application by moving its window to the bottom.
+ *
+ * @param application. The new application to add to the task bar
+ * @return true on success
+ */
+
+ bool hideApplication(IApplication *application);
+
+ /**
+ * Destroy an application. Move its window to the bottom and remove its
+ * icon from the task bar.
+ *
+ * @param application. The new application to remove from the task bar
+ * @return true on success
+ */
+
+ bool stopApplication(IApplication *application);
+ };
+}
+
+#endif // __cplusplus
+#endif // __NXWM_INCLUDE_CTASKBAR_HXX