diff options
author | Bent Bisballe Nyeng <deva@aasimon.org> | 2016-11-26 18:58:14 +0100 |
---|---|---|
committer | Bent Bisballe Nyeng <deva@aasimon.org> | 2017-01-21 14:51:30 +0100 |
commit | 29639f5b6da42fc976c883351ef508020f821b59 (patch) | |
tree | 5e80827063a09d983158ff8e9ad507a2b7b6e6b5 /plugingui | |
parent | 586fac8e8daa7665302b075f900d8d2df90716f9 (diff) |
New MainWindow.
Diffstat (limited to 'plugingui')
-rw-r--r-- | plugingui/Makefile.am.plugingui | 1 | ||||
-rw-r--r-- | plugingui/Makefile.mingw32 | 4 | ||||
-rw-r--r-- | plugingui/mainwindow.cc | 103 | ||||
-rw-r--r-- | plugingui/mainwindow.h | 75 | ||||
-rw-r--r-- | plugingui/nativewindow_x11.cc | 3 | ||||
-rw-r--r-- | plugingui/testmain.cc | 46 |
6 files changed, 194 insertions, 38 deletions
diff --git a/plugingui/Makefile.am.plugingui b/plugingui/Makefile.am.plugingui index 42824cc..d790f64 100644 --- a/plugingui/Makefile.am.plugingui +++ b/plugingui/Makefile.am.plugingui @@ -16,6 +16,7 @@ PLUGIN_GUI_SOURCES = \ $(top_srcdir)/plugingui/lineedit.cc \ $(top_srcdir)/plugingui/led.cc \ $(top_srcdir)/plugingui/checkbox.cc \ + $(top_srcdir)/plugingui/mainwindow.cc \ $(top_srcdir)/plugingui/slider.cc \ $(top_srcdir)/plugingui/scrollbar.cc \ $(top_srcdir)/plugingui/stackedwidget.cc \ diff --git a/plugingui/Makefile.mingw32 b/plugingui/Makefile.mingw32 index 68d70bc..33a8f54 100644 --- a/plugingui/Makefile.mingw32 +++ b/plugingui/Makefile.mingw32 @@ -24,12 +24,16 @@ GUI_SRC = \ lineedit.cc \ led.cc \ layout.cc \ + mainwindow.cc \ checkbox.cc \ slider.cc \ scrollbar.cc \ + stackedwidget.cc \ textedit.cc \ texture.cc \ texturedbox.cc \ + tabbutton.cc \ + tabwidget.cc \ listbox.cc \ listboxthin.cc \ listboxbasic.cc \ diff --git a/plugingui/mainwindow.cc b/plugingui/mainwindow.cc new file mode 100644 index 0000000..cff6b04 --- /dev/null +++ b/plugingui/mainwindow.cc @@ -0,0 +1,103 @@ +/* -*- Mode: C++; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2 -*- */ +/*************************************************************************** + * mainwindow.cc + * + * Sat Nov 26 14:27:29 CET 2016 + * Copyright 2016 Bent Bisballe Nyeng + * deva@aasimon.org + ****************************************************************************/ + +/* + * This file is part of DrumGizmo. + * + * DrumGizmo is free software; you can redistribute it and/or modify + * it under the terms of the GNU Lesser General Public License as published by + * the Free Software Foundation; either version 3 of the License, or + * (at your option) any later version. + * + * DrumGizmo is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + * GNU Lesser General Public License for more details. + * + * You should have received a copy of the GNU Lesser General Public License + * along with DrumGizmo; if not, write to the Free Software + * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA. + */ +#include "mainwindow.h" + +#include <config.h> + +#include "painter.h" + +namespace GUI +{ + +MainWindow::MainWindow(Settings& settings, void* native_window) + : Window(native_window) + , settings(settings) +{ + CONNECT(this, sizeChangeNotifier, this, &MainWindow::sizeChanged); + CONNECT(eventHandler(), closeNotifier, this, &MainWindow::closeEventHandler); + resize(370, 330); + tabs.move(16, 0); // x-offset to make room for the left side bar. + setCaption("DrumGizmo v" VERSION); +} + +bool MainWindow::processEvents() +{ +// if(!initialised) +// { +// return running; +// } + + eventHandler()->processEvents(); + + { + Painter p(*this); + settings_notifier.evaluate(); + } + + if(closing) + { + closeNotifier(); + closing = false; + return false; + } + + return true; +} + +void MainWindow::repaintEvent(RepaintEvent* repaintEvent) +{ + if(!visible()) + { + return; + } + + Painter painter(*this); + + // Grey background + painter.drawImageStretched(0, 0, back, width(), height()); + + // DrumGizmo logo + painter.drawImage(width() - logo.width() - 16, + height() - logo.height(), logo); + + // Sidebars + sidebar.setSize(16, height()); + painter.drawImage(0, 0, sidebar); + painter.drawImage(width() - 16, 0, sidebar); +} + +void MainWindow::sizeChanged(int width, int height) +{ + tabs.resize(width - 2 * 16, height); +} + +void MainWindow::closeEventHandler() +{ + closing = true; +} + +} // GUI:: diff --git a/plugingui/mainwindow.h b/plugingui/mainwindow.h new file mode 100644 index 0000000..bfef4a0 --- /dev/null +++ b/plugingui/mainwindow.h @@ -0,0 +1,75 @@ +/* -*- Mode: C++; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2 -*- */ +/*************************************************************************** + * mainwindow.h + * + * Sat Nov 26 14:27:28 CET 2016 + * Copyright 2016 Bent Bisballe Nyeng + * deva@aasimon.org + ****************************************************************************/ + +/* + * This file is part of DrumGizmo. + * + * DrumGizmo is free software; you can redistribute it and/or modify + * it under the terms of the GNU Lesser General Public License as published by + * the Free Software Foundation; either version 3 of the License, or + * (at your option) any later version. + * + * DrumGizmo is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + * GNU Lesser General Public License for more details. + * + * You should have received a copy of the GNU Lesser General Public License + * along with DrumGizmo; if not, write to the Free Software + * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA. + */ +#pragma once + +#include <settings.h> + +#include "window.h" +#include "tabwidget.h" +#include "texturedbox.h" +#include "image.h" + +namespace GUI +{ + +class MainWindow + : public Window +{ +public: + MainWindow(Settings& settings, void* native_window); + + //! Process all events and messages in queue + //! \return true if not closing, returns false if closing. + bool processEvents(); + + //! Notify when window is closing. + Notifier<> closeNotifier; + +private: + void sizeChanged(int width, int height); + void closeEventHandler(); + + // From Widget + void repaintEvent(RepaintEvent* repaintEvent) override final; + + TabWidget tabs{this}; + + Image back{":bg.png"}; + Image logo{":logo.png"}; + + TexturedBox sidebar{getImageCache(), ":sidebar.png", + 0, 0, // offset + 16, 0, 0, // delta-x + 14, 1, 14}; // delta-y + + bool closing{false}; + + Settings& settings; + SettingsNotifier settings_notifier{settings}; +}; + +} // GUI:: diff --git a/plugingui/nativewindow_x11.cc b/plugingui/nativewindow_x11.cc index b579fb3..5d239ea 100644 --- a/plugingui/nativewindow_x11.cc +++ b/plugingui/nativewindow_x11.cc @@ -89,9 +89,6 @@ NativeWindowX11::NativeWindowX11(void* native_window, Window& window) int count = sizeof(protocols)/sizeof(Atom); XSetWMProtocols(display, xwindow, protocols, count); - // "Map" the window (that is, make it appear on the screen) - XMapWindow(display, xwindow); - // Create a "Graphics Context" gc = XCreateGC(display, xwindow, 0, nullptr); } diff --git a/plugingui/testmain.cc b/plugingui/testmain.cc index 84d813d..c4ca18d 100644 --- a/plugingui/testmain.cc +++ b/plugingui/testmain.cc @@ -24,56 +24,32 @@ * along with DrumGizmo; if not, write to the Free Software * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA. */ -#include "plugingui.h" - #ifdef WIN32 #define WIN32_LEAN_AND_MEAN #include <windows.h> #endif #include <hugin.hpp> - -#include <notifier.h> #include <settings.h> -class TestMain : public Listener { -public: - TestMain() - { - CONNECT(&gui, closeNotifier, this, &TestMain::stop); - } +#include "mainwindow.h" - void stop() - { - DEBUG(stop, "Stopping...\n"); - running = false; - } +int main() +{ + INFO(example, "We are up and running"); - void run() + Settings settings; + GUI::MainWindow main_window(settings, nullptr); + main_window.show(); + + while(main_window.processEvents()) { - while(running) - { #ifdef WIN32 - SleepEx(50, FALSE); + SleepEx(50, FALSE); #else - usleep(50000); + usleep(50000); #endif - gui.processEvents(); - } } - bool running = true; - - Settings settings; - GUI::PluginGUI gui{settings}; -}; - -int main() -{ - INFO(example, "We are up and running"); - - TestMain testMain; - testMain.run(); - return 0; } |