From 1d3abc8d480110850480ca27560e6a9672052e0b Mon Sep 17 00:00:00 2001 From: patacongo Date: Mon, 30 Apr 2012 22:51:34 +0000 Subject: More NX window manager updates git-svn-id: svn://svn.code.sf.net/p/nuttx/code/trunk@4679 42af7a65-404d-4744-a932-0658087f49c3 --- NxWidgets/libnxwidgets/include/crect.hxx | 12 + NxWidgets/nxwm/Makefile | 2 +- NxWidgets/nxwm/include/cstartwindow.hxx | 83 +++++- NxWidgets/nxwm/include/ctaskbar.hxx | 2 +- NxWidgets/nxwm/include/iapplication.hxx | 12 +- NxWidgets/nxwm/include/nxwmconfig.hxx | 19 +- NxWidgets/nxwm/src/cstartwindow.cxx | 452 +++++++++++++++++++++++++++++++ NxWidgets/nxwm/src/ctaskbar.cxx | 19 +- NxWidgets/nxwm/src/glyph_nsh.cxx | 0 NxWidgets/nxwm/src/glyph_start.cxx | 0 NxWidgets/nxwm/src/glyph_stop.cxx | 0 11 files changed, 576 insertions(+), 25 deletions(-) create mode 100644 NxWidgets/nxwm/src/cstartwindow.cxx mode change 100755 => 100644 NxWidgets/nxwm/src/glyph_nsh.cxx mode change 100755 => 100644 NxWidgets/nxwm/src/glyph_start.cxx mode change 100755 => 100644 NxWidgets/nxwm/src/glyph_stop.cxx diff --git a/NxWidgets/libnxwidgets/include/crect.hxx b/NxWidgets/libnxwidgets/include/crect.hxx index e3a73a392..7ce233fed 100644 --- a/NxWidgets/libnxwidgets/include/crect.hxx +++ b/NxWidgets/libnxwidgets/include/crect.hxx @@ -183,6 +183,18 @@ namespace NXWidgets return m_size.w; } + /** + * Get the size of the rectangle + * + * @return The rectangle's size + */ + + inline void getSize(struct nxgl_size_s &size) const + { + size.h = m_size.h; + size.w = m_size.w; + } + /** * Get the rectangle's height. * diff --git a/NxWidgets/nxwm/Makefile b/NxWidgets/nxwm/Makefile index 0dea92d62..4f13ca362 100644 --- a/NxWidgets/nxwm/Makefile +++ b/NxWidgets/nxwm/Makefile @@ -42,7 +42,7 @@ NXWIDGETDIR := $(NXWMDIR)/../libnxwidgets ASRCS = CSRCS = # Window Manager -CXXSRCS = capplicationwindow.cxx cnxconsole.cxx ctaskbar.cxx +CXXSRCS = capplicationwindow.cxx cnxconsole.cxx cstartwindow.cxx ctaskbar.cxx # Images CXXSRCS += glyph_minimize.cxx glyph_nsh.cxx glyph_start.cxx glyph_stop.cxx diff --git a/NxWidgets/nxwm/include/cstartwindow.hxx b/NxWidgets/nxwm/include/cstartwindow.hxx index 2a1dac088..fca886e8d 100644 --- a/NxWidgets/nxwm/include/cstartwindow.hxx +++ b/NxWidgets/nxwm/include/cstartwindow.hxx @@ -42,9 +42,11 @@ #include -#include "iapplication.hxx" #include "tnxarray.hxx" +#include "iapplication.hxx" +#include "capplicationwindow.hxx" + /**************************************************************************** * Pre-Processor Definitions ****************************************************************************/ @@ -58,13 +60,61 @@ namespace NxWM { class CTaskbar; - class CApplicationWindow; - class CStartWindow : public IApplication + class CStartWindow : public IApplication, private IApplicationCallback, + private NXWidgets::CWidgetEventHandler { protected: - CTaskbar *m_taskbar; /**< Reference to the "parent" taskbar */ - TNxArray m_applications; /**< List of apps in the start window */ + /** + * This structure represents an application and its associated icon image + */ + + struct SStartWindowSlot + { + IApplication *app; /**< A reference to the icon */ + NXWidgets::CImage *image; /**< The icon image that goes with the application */ + }; + + /** + * CStartWindow state data + */ + + CTaskbar *m_taskbar; /**< Reference to the "parent" taskbar */ + CApplicationWindow *m_window; /**< Reference to the application window */ + TNxArray m_slots; /**< List of apps in the start window */ + struct nxgl_size_s m_iconSize; /**< A box big enough to hold the largest icon */ + + /** + * Called when the window minimize button is pressed. + */ + + void minimize(void); + + /** + * Called when the window minimize close is pressed. + */ + + void close(void); + + /** + * Calculate the icon bounding box + */ + + void getIconBounds(void); + + /** + * Stop all applications + */ + + void stopAllApplications(void); + + /** + * Handle a mouse button click event. + * + * @param e The event data. + */ + + void handleClickEvent(const NXWidgets::CWidgetEventArgs &e); /** * CStartWindow Constructor @@ -112,13 +162,28 @@ namespace NxWM * Start the application. */ - run(void); + void run(void); /** * Stop the application. */ - stop(void); + void stop(void); + + /** + * The application window is hidden (either it is minimized or it is + * maximized, but not at the top of the hierarchy + */ + + void hide(void); + + /** + * Redraw the entire window. The application has been maximized or + * otherwise moved to the top of the hiearchy. This method is call from + * CTaskbar when the application window must be displayed + */ + + virtual void redraw(void) = 0; /** * Add the application to the start window. The general sequence for @@ -131,11 +196,11 @@ namespace NxWM * 4. Call CTaskBar::startApplication (initially minimized) to start the start * window application. * - * @param application. The new application to add to the start window + * @param app. The new application to add to the start window * @return true on success */ - bool addApplication(IApplication *application); + bool addApplication(IApplication *app); }; } diff --git a/NxWidgets/nxwm/include/ctaskbar.hxx b/NxWidgets/nxwm/include/ctaskbar.hxx index ef25fd563..1de4a7491 100644 --- a/NxWidgets/nxwm/include/ctaskbar.hxx +++ b/NxWidgets/nxwm/include/ctaskbar.hxx @@ -81,7 +81,7 @@ namespace NxWM { private: /** - * This structgure represents an application and its associated icon image + * This structure represents an application and its associated icon image */ struct STaskbarSlot diff --git a/NxWidgets/nxwm/include/iapplication.hxx b/NxWidgets/nxwm/include/iapplication.hxx index 88583d4c5..885b85710 100644 --- a/NxWidgets/nxwm/include/iapplication.hxx +++ b/NxWidgets/nxwm/include/iapplication.hxx @@ -111,8 +111,16 @@ namespace NxWM virtual void stop(void) = 0; /** - * Re-draw the application window. This method is call from CTaskbar - * when the application window must be displayed + * The application window is hidden (either it is minimized or it is + * maximized, but not at the top of the hierarchy + */ + + virtual void hide(void) = 0; + + /** + * Redraw the entire window. The application has been maximized or + * otherwise moved to the top of the hierarchy. This method is call from + * CTaskbar when the application window must be displayed */ virtual void redraw(void) = 0; diff --git a/NxWidgets/nxwm/include/nxwmconfig.hxx b/NxWidgets/nxwm/include/nxwmconfig.hxx index d416bf8f0..cdbcee564 100644 --- a/NxWidgets/nxwm/include/nxwmconfig.hxx +++ b/NxWidgets/nxwm/include/nxwmconfig.hxx @@ -173,16 +173,29 @@ # endif #endif +/* Tool Bar Configuration ***************************************************/ + +#ifndef CONFIG_NXWM_TOOLBAR_HEIGHT +# define CONFIG_NXWM_TOOLBAR_HEIGHT CONFIG_NXWM_TASKBAR_WIDTH +#endif + /* Background Image **********************************************************/ #ifndef CONFIG_NXWM_BACKGROUND_IMAGE # define CONFIG_NXWM_BACKGROUND_IMAGE NXWidgets::g_nuttxBitmap #endif -/* Tool Bar Configuration ***************************************************/ +/* Start Window Configuration ***********************************************/ +/** + * Horizontal and vertical spacing of icons in the task bar. + */ -#ifndef CONFIG_NXWM_TOOLBAR_HEIGHT -# define CONFIG_NXWM_TOOLBAR_HEIGHT CONFIG_NXWM_TASKBAR_WIDTH +#ifndef CONFIG_NXWM_STARTWINDOW_VSPACING +# define CONFIG_NXWM_STARTWINDOW_VSPACING (2) +#endif + +#ifndef CONFIG_NXWM_STARTWINDOW_HSPACING +# define CONFIG_NXWM_STARTWINDOW_HSPACING (2) #endif #endif // __INCLUDE_NXWMCONFIG_HXX diff --git a/NxWidgets/nxwm/src/cstartwindow.cxx b/NxWidgets/nxwm/src/cstartwindow.cxx new file mode 100644 index 000000000..4213c33cb --- /dev/null +++ b/NxWidgets/nxwm/src/cstartwindow.cxx @@ -0,0 +1,452 @@ +/******************************************************************************************** + * NxWidgets/nxwm/src/cnxconsole.cxx + * + * Copyright (C) 2012 Gregory Nutt. All rights reserved. + * Author: Gregory Nutt + * + * 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. + * + ********************************************************************************************/ + +/******************************************************************************************** + * Included Files + ********************************************************************************************/ + +#include + +#include "cwidgetcontrol.hxx" + +#include "nxwmconfig.hxx" +#include "nxwmglyphs.hxx" +#include "ctaskbar.hxx" +#include "cstartwindow.hxx" + +/******************************************************************************************** + * Pre-Processor Definitions + ********************************************************************************************/ + +/******************************************************************************************** + * CNxConsole Method Implementations + ********************************************************************************************/ + +using namespace NxWM; + +/** + * CStartWindow Constructor + * + * @param taskbar. A pointer to the parent task bar instance + * @param window. The window to be used by this application. + */ + +CStartWindow::CStartWindow(CTaskbar *taskbar, CApplicationWindow *window) +{ + // Save the constructor data + + m_taskbar = taskbar; + m_window = window; + + // Add out callbacks to the application window + + window->registerCallbacks(static_cast(this)); +} + +/** + * CStartWindow Constructor + */ + +CStartWindow::~CStartWindow(void) +{ + // Although we didn't create it, we are responsible for deleting the + // application window + + if (m_window) + { + delete m_window; + } + + // Then stop and delete all applications + + stopAllApplications(); +} + +/** + * Each implementation of IApplication must provide a method to recover + * the contained CApplicationWindow instance. + */ + +CApplicationWindow *CStartWindow::getWindow(void) const +{ + return m_window; +} + +/** + * Get the icon associated with the application + * + * @return An instance if IBitmap that may be used to rend the + * application's icon. This is an new IBitmap instance that must + * be deleted by the caller when it is no long needed. + */ + +NXWidgets::IBitmap *CStartWindow::getIcon(void) +{ + NXWidgets::CRlePaletteBitmap *bitmap = + new NXWidgets::CRlePaletteBitmap(&g_startBitmap); + + return bitmap; +} + +/** + * Get the name string associated with the application + * + * @return A copy if CNxString that contains the name of the application. + */ + +NXWidgets::CNxString CStartWindow::getName(void) +{ + return NXWidgets::CNxString("Start Window"); +} + +/** + * Start the application. + */ + +void CStartWindow::run(void) +{ + // We don't have a thread of execution. We only respond to button presses +} + +/** + * Stop the application. + */ + +void CStartWindow::stop(void) +{ + // We don't have a thread of execution. We only respond to button presses +} + +/** + * The application window is hidden (either it is minimized or it is + * maximized, but not at the top of the hierarchy + */ + +void CStartWindow::hide(void) +{ + // Disable drawing and events on all icons + + for (int i = 0; i < m_slots.size(); i++) + { + NXWidgets::CImage *image = m_slots.at(i).image; + image->disableDrawing(); + image->setRaisesEvents(false); + } +} + +/** + * Redraw the entire window. The application has been maximized or + * otherwise moved to the top of the hiearchy + */ + +void CStartWindow::redraw(void) +{ + // Recover the NXTK window instance contained in the application window + + NXWidgets::CNxTkWindow *window = m_window->getWindow(); + + // Get the widget control associated with the NXTK window + + NXWidgets::CWidgetControl *control = window->getWidgetControl(); + + // Get the graphics port for drawing on the widget control + + NXWidgets::CGraphicsPort *port = control->getGraphicsPort(); + + // Get the size of the application window + + struct nxgl_size_s windowSize; + if (!window->getSize(&windowSize)) + { + return; + } + + // Fill the entire window with the background color + + port->drawFilledRect(0, 0, windowSize.w, windowSize.h, + CONFIG_NXWM_DEFAULT_BACKGROUNDCOLOR); + + // Begin adding icons in the upper left corner + + struct nxgl_point_s iconPos; + iconPos.x = CONFIG_NXWM_STARTWINDOW_HSPACING; + iconPos.y = CONFIG_NXWM_STARTWINDOW_VSPACING; + + // Add each icon in the list of applications + + for (int i = 0; i < m_slots.size(); i++) + { + // Get the icon associated with this application + + NXWidgets::CImage *image = m_slots.at(i).image; + + // Disable drawing of the icon image; disable events from the icon + + image->disableDrawing(); + image->setRaisesEvents(false); + + // Get the size of the icon image + + NXWidgets::CRect rect; + image->getPreferredDimensions(rect); + + // Center the image in the region defined by the maximum icon size + + struct nxgl_point_s imagePos; + imagePos.x = iconPos.x; + imagePos.y = iconPos.y; + + if (rect.getWidth() < m_iconSize.w) + { + imagePos.x += ((m_iconSize.w - rect.getWidth()) >> 1); + } + + if (rect.getHeight() < m_iconSize.h) + { + imagePos.y += ((m_iconSize.h - rect.getHeight()) >> 1); + } + + // Set the position of the icon bitmap + + image->moveTo(imagePos.x, imagePos.y); + + // Then re-draw the icon at the new position + + image->enableDrawing(); + image->redraw(); + image->setRaisesEvents(true); + + // Advance the next icon position to the left + + iconPos.x += m_iconSize.w + CONFIG_NXWM_TASKBAR_HSPACING; + + // If there is insufficient space on on this row for the next + // max-sized icon, then advance to the next row + + if (iconPos.x + m_iconSize.w >= windowSize.w) + { + iconPos.x = CONFIG_NXWM_STARTWINDOW_HSPACING; + iconPos.y += m_iconSize.h + CONFIG_NXWM_TASKBAR_VSPACING; + + // Don't try drawing past the bottom of the window + + if (iconPos.y >= windowSize.w) + { + break; + } + } + } +} + +/** + * Add the application to the start window. The general sequence for + * setting up the start window is: + * + * 1. Call CTaskBar::openApplicationWindow to create a window for the start window, + * 2. Use the window to instantiate CStartMenu + * 3. Call CStartMenu::addApplication numerous times to install applications + * in the start window. + * 4. Call CTaskBar::startApplication (initially minimized) to start the start + * window application. + * + * @param app. The new application to add to the start window + * @return true on success + */ + +bool CStartWindow::addApplication(IApplication *app) +{ + // Recover the NXTK window instance contained in the application window + + NXWidgets::CNxTkWindow *window = m_window->getWindow(); + + // Get the widget control associated with the NXTK window + + NXWidgets::CWidgetControl *control = window->getWidgetControl(); + + // Get the bitmap icon that goes with this application + + NXWidgets::IBitmap *bitmap = app->getIcon(); + + // Create a CImage instance to manage the application icon + + NXWidgets::CImage *image = + new NXWidgets::CImage(control, 0, 0, bitmap->getWidth(), + bitmap->getHeight(), bitmap, 0); + if (!image) + { + return false; + } + + // Configure the image, disabling drawing for now + + image->setBorderless(true); + image->disableDrawing(); + + // Register to get events from the mouse clicks on the image + + image->addWidgetEventHandler(this); + + // Add the application to end of the list of applications managed by + // the start window + + struct SStartWindowSlot slot; + slot.app = app; + slot.image = image; + m_slots.push_back(slot); + + // Re-calculate the icon bounding box + + getIconBounds(); + return true; +} + +/** + * Called when the window minimize button is pressed. + */ + +void CStartWindow::minimize(void) +{ + m_taskbar->minimizeApplication(static_cast(this)); +} + +/** + * Called when the window minimize close is pressed. + */ + +void CStartWindow::close(void) +{ + m_taskbar->stopApplication(static_cast(this)); +} + +/** + * Calculate the icon bounding box + */ + +void CStartWindow::getIconBounds(void) +{ + // Visit each icon + + struct nxgl_size_s maxSize; + maxSize.w = 0; + maxSize.h = 0; + + for (int i = 0; i < m_slots.size(); i++) + { + // Get the icon associated with this application + + NXWidgets::CImage *image = m_slots.at(i).image; + + // Get the size of the icon image + + NXWidgets::CRect rect; + image->getPreferredDimensions(rect); + + // Keep the maximum height and width + + if (rect.getWidth() > maxSize.h) + { + maxSize.w = rect.getWidth() ; + } + + if (rect.getHeight() > maxSize.h) + { + maxSize.h = rect.getHeight(); + } + } + + // And save the new maximum size + + m_iconSize.w = maxSize.w; + m_iconSize.h = maxSize.h; +} + +/** + * Stop all applications + */ + +void CStartWindow::stopAllApplications(void) +{ + // Stop all applications and remove them from the task bar. Clearly, there + // are some ordering issues here... On an orderly system shutdown, disconnection + // should really occur priority to deleting instances + + while (!m_slots.empty()) + { + // Stop the application (and remove it from the task bar) + + IApplication *app = m_slots.at(0).app; + m_taskbar->stopApplication(app); + + // Now, delete the image and the application + + delete app; + delete m_slots.at(0).image; + + // And discard the data in this slot + + m_slots.erase(0); + } +} + +/** + * Handle a mouse button click event. + * + * @param e The event data. + */ + +void CStartWindow::handleClickEvent(const NXWidgets::CWidgetEventArgs &e) +{ + // icon was clicked? + + for (int i = 0; i < m_slots.size(); i++) + { + // Is this the clicked icon? + + NXWidgets::CImage *image = m_slots.at(i).image; + if (image->isClicked()) + { + // Start a new copy of the application + + m_taskbar->startApplication(m_slots.at(i).app, false); + + // Then break out of the loop + + break; + } + } +} + + + diff --git a/NxWidgets/nxwm/src/ctaskbar.cxx b/NxWidgets/nxwm/src/ctaskbar.cxx index 42cb41087..3791ee0f6 100644 --- a/NxWidgets/nxwm/src/ctaskbar.cxx +++ b/NxWidgets/nxwm/src/ctaskbar.cxx @@ -163,14 +163,14 @@ bool CTaskbar::startWindowManager(void) * Create an application window. Creating a new application in the start * window requires three steps: * - * 1. Call openApplicationWindow to create a window for the application, + * 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 addApplication to add the application to the start window. + * 3. Then call CStartWindow::addApplication to add the application to the start window. * * When the application is selected from the start window: * - * 4. Call startApplication start the application and bring its window to + * 4. Call CTaskBar::startApplication start the application and bring its window to * the top. */ @@ -242,6 +242,7 @@ bool CTaskbar::startApplication(IApplication *app, bool minimized) image->setBorderless(true); image->disableDrawing(); + image->setRaisesEvents(false); // Register to get events from the mouse clicks on the image @@ -393,7 +394,7 @@ bool CTaskbar::stopApplication(IApplication *app) minimizeApplication(app); - // Stop the appliation + // Stop the application app->stop(); @@ -863,9 +864,10 @@ bool CTaskbar::redrawTaskbarWindow(void) NXWidgets::CImage *image = m_slots.at(i).image; - // Disable drawing of the icon image + // Disable drawing of the icon image; disable events from the icon image->disableDrawing(); + image->setRaisesEvents(false); // Get the size of the icon image @@ -895,8 +897,9 @@ bool CTaskbar::redrawTaskbarWindow(void) // Then re-draw the icon at the new position - (void)image->enableDrawing(); - (void)image->redraw(); + image->enableDrawing(); + image->redraw(); + image->setRaisesEvents(true); // Do we add icons left-to-right? Or top-to-bottom? @@ -1051,5 +1054,3 @@ void CTaskbar::handleClickEvent(const NXWidgets::CWidgetEventArgs &e) } } } - - diff --git a/NxWidgets/nxwm/src/glyph_nsh.cxx b/NxWidgets/nxwm/src/glyph_nsh.cxx old mode 100755 new mode 100644 diff --git a/NxWidgets/nxwm/src/glyph_start.cxx b/NxWidgets/nxwm/src/glyph_start.cxx old mode 100755 new mode 100644 diff --git a/NxWidgets/nxwm/src/glyph_stop.cxx b/NxWidgets/nxwm/src/glyph_stop.cxx old mode 100755 new mode 100644 -- cgit v1.2.3