diff -r a70dd25dd4bb -r a350c4b25133 src/widgets.cpp
--- a/src/widgets.cpp Fri Aug 16 11:05:21 2013 +0300
+++ b/src/widgets.cpp Sat Sep 07 13:23:09 2013 +0300
@@ -1,21 +1,25 @@
/*
* LDForge: LDraw parts authoring CAD
* Copyright (C) 2013 Santeri Piippo
- *
+ *
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
- *
+ *
* This program 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 General Public License for more details.
- *
+ *
* You should have received a copy of the GNU General Public License
* along with this program. If not, see .
*/
+// I still find the radio group useful... find a way to use this in Designer.
+// I probably need to look into how to make Designer plugins.
+// TODO: try make this usable in Designer
+
#include
#include
#include
@@ -24,19 +28,27 @@
#include "widgets.h"
-RadioBox::RadioBox (const QString& title, QWidget* parent) : QGroupBox (title, parent) {
+// =============================================================================
+// -----------------------------------------------------------------------------
+RadioGroup::RadioGroup (const QString& title, QWidget* parent) : QGroupBox (title, parent) {
init (Qt::Vertical);
}
+// =============================================================================
+// -----------------------------------------------------------------------------
QBoxLayout::Direction makeDirection (Qt::Orientation orient, bool invert = false) {
return (orient == (invert ? Qt::Vertical : Qt::Horizontal)) ? QBoxLayout::LeftToRight : QBoxLayout::TopToBottom;
}
-bool RadioBox::isChecked (int n) const {
+// =============================================================================
+// -----------------------------------------------------------------------------
+bool RadioGroup::isChecked (int n) const {
return m_buttonGroup->checkedId() == n;
}
-void RadioBox::init (Qt::Orientation orient) {
+// =============================================================================
+// -----------------------------------------------------------------------------
+void RadioGroup::init (Qt::Orientation orient) {
m_vert = orient == Qt::Vertical;
m_buttonGroup = new QButtonGroup;
@@ -53,7 +65,9 @@
connect (m_buttonGroup, SIGNAL (buttonReleased (int)), this, SLOT (slot_buttonReleased (int)));
}
-RadioBox::RadioBox (const QString& title, initlist entries, int const defaultId,
+// =============================================================================
+// -----------------------------------------------------------------------------
+RadioGroup::RadioGroup (const QString& title, initlist entries, int const defaultId,
const Qt::Orientation orient, QWidget* parent) : QGroupBox (title, parent), m_defId (defaultId)
{
init (orient);
@@ -63,7 +77,9 @@
addButton (entry);
}
-void RadioBox::rowBreak() {
+// =============================================================================
+// -----------------------------------------------------------------------------
+void RadioGroup::rowBreak() {
QBoxLayout* newLayout = new QBoxLayout (m_vert ? QBoxLayout::TopToBottom : QBoxLayout::LeftToRight);
m_currentLayout = newLayout;
m_layouts << newLayout;
@@ -71,12 +87,16 @@
m_coreLayout->addLayout (newLayout);
}
-void RadioBox::addButton (const char* entry) {
+// =============================================================================
+// -----------------------------------------------------------------------------
+void RadioGroup::addButton (const char* entry) {
QRadioButton* button = new QRadioButton (entry);
addButton (button);
}
-void RadioBox::addButton (QRadioButton* button) {
+// =============================================================================
+// -----------------------------------------------------------------------------
+void RadioGroup::addButton (QRadioButton* button) {
bool const selectThis = (m_curId == m_defId);
m_objects << button;
@@ -87,39 +107,55 @@
button->setChecked (true);
}
-RadioBox& RadioBox::operator<< (QRadioButton* button) {
+// =============================================================================
+// -----------------------------------------------------------------------------
+RadioGroup& RadioGroup::operator<< (QRadioButton* button) {
addButton (button);
return *this;
}
-RadioBox& RadioBox::operator<< (const char* entry) {
+// =============================================================================
+// -----------------------------------------------------------------------------
+RadioGroup& RadioGroup::operator<< (const char* entry) {
addButton (entry);
return *this;
}
-void RadioBox::setCurrentRow (uint row) {
+// =============================================================================
+// -----------------------------------------------------------------------------
+void RadioGroup::setCurrentRow (uint row) {
m_currentLayout = m_layouts[row];
}
-int RadioBox::value() const {
+// =============================================================================
+// -----------------------------------------------------------------------------
+int RadioGroup::value() const {
return m_buttonGroup->checkedId();
}
-void RadioBox::setValue (int val) {
+// =============================================================================
+// -----------------------------------------------------------------------------
+void RadioGroup::setValue (int val) {
m_buttonGroup->button (val)->setChecked (true);
}
-QRadioButton* RadioBox::operator[] (uint n) const {
+// =============================================================================
+// -----------------------------------------------------------------------------
+QRadioButton* RadioGroup::operator[] (uint n) const {
return m_objects[n];
}
-void RadioBox::slot_buttonPressed (int btn) {
+// =============================================================================
+// -----------------------------------------------------------------------------
+void RadioGroup::slot_buttonPressed (int btn) {
emit buttonPressed (btn);
m_oldId = m_buttonGroup->checkedId();
}
-void RadioBox::slot_buttonReleased (int btn) {
+// =============================================================================
+// -----------------------------------------------------------------------------
+void RadioGroup::slot_buttonReleased (int btn) {
emit buttonReleased (btn);
int newid = m_buttonGroup->checkedId();
@@ -127,12 +163,14 @@
emit valueChanged (newid);
}
-RadioBox::it RadioBox::begin() {
+// =============================================================================
+// -----------------------------------------------------------------------------
+RadioGroup::it RadioGroup::begin() {
return m_objects.begin();
}
-RadioBox::it RadioBox::end() {
+// =============================================================================
+// -----------------------------------------------------------------------------
+RadioGroup::it RadioGroup::end() {
return m_objects.end();
-}
-
-#include "build/moc_widgets.cpp"
\ No newline at end of file
+}
\ No newline at end of file