src/widgets/colorbutton.cpp

Fri, 21 Dec 2018 21:43:06 +0200

author
Teemu Piippo <teemu@hecknology.net>
date
Fri, 21 Dec 2018 21:43:06 +0200
changeset 1431
2e0e2c696605
parent 1396
3442a59ab05c
permissions
-rw-r--r--

things

/*
 *  LDForge: LDraw parts authoring CAD
 *  Copyright (C) 2013 - 2018 Teemu 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 <http://www.gnu.org/licenses/>.
 */

#include "colorbutton.h"
#include "../dialogs/colorselector.h"

/*
 * Initializes the color button and sets the default color
 */
ColorButton::ColorButton(LDColor color, QWidget* parent) :
	ColorButton (parent)
{
	setColor(color);
}

/*
 * Initializes the color button
 */
ColorButton::ColorButton(QWidget* parent) :
	QPushButton (parent)
{
	connect(
		this,
		&QPushButton::clicked,
		[&]()
		{
			// The dialog must not have the button as the parent or the dialog inherits the stylesheet.
			ColorSelector dialog {qobject_cast<QWidget*>(this->parent()), _color};

			if (dialog.exec() and dialog.selectedColor().isValid())
				setColor(dialog.selectedColor());
		}
	);

	connect(
		this,
		&ColorButton::colorChanged,
		[&](LDColor)
		{
			if (_color.isValid())
			{
				setFlat(true);
				setText(format("[%1] %2", _color.indexString(), _color.name()));
				setStyleSheet(format(
					"background-color: %1; color: %2; border:none;",
					_color.hexcode(),
					_color.edgeColor().name()
				));
			}
			else
			{
				setFlat(false);
				setText("");
				setStyleSheet("");
			}
		}
	);
}

/*
 * Returns the currently selected color.
 */
LDColor ColorButton::color() const
{
	return _color;
}

/*
 * Sets the currently selected color.
 */
void ColorButton::setColor(LDColor color)
{
	_color = color;
	emit colorChanged(color);
}

mercurial