2020-05-08 00:08:57 +02:00
|
|
|
/*
|
2021-02-20 12:13:46 +01:00
|
|
|
Copyright 2006-2021 The QElectroTech Team
|
2020-08-16 09:40:14 +02:00
|
|
|
This file is part of QElectroTech.
|
2020-05-08 00:08:57 +02:00
|
|
|
|
2020-08-16 09:40:14 +02:00
|
|
|
QElectroTech 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 2 of the License, or
|
|
|
|
(at your option) any later version.
|
2020-05-08 00:08:57 +02:00
|
|
|
|
2020-08-16 09:40:14 +02:00
|
|
|
QElectroTech 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.
|
2020-05-08 00:08:57 +02:00
|
|
|
|
2020-08-16 09:40:14 +02:00
|
|
|
You should have received a copy of the GNU General Public License
|
|
|
|
along with QElectroTech. If not, see <http://www.gnu.org/licenses/>.
|
2020-05-08 00:08:57 +02:00
|
|
|
*/
|
|
|
|
#include "qetutils.h"
|
|
|
|
#include <QString>
|
|
|
|
#include <QStringList>
|
2022-01-03 21:01:25 +01:00
|
|
|
#include <QGraphicsView>
|
|
|
|
#include "../qetapp.h"
|
|
|
|
#include "../qetdiagrameditor.h"
|
2020-05-08 00:08:57 +02:00
|
|
|
|
2020-07-15 18:02:11 +02:00
|
|
|
/**
|
|
|
|
@brief QETUtils::marginsToString
|
|
|
|
@param margins
|
|
|
|
@return QString str "left;top;right;bottom"
|
|
|
|
*/
|
2020-05-08 00:08:57 +02:00
|
|
|
QString QETUtils::marginsToString(const QMargins &margins)
|
|
|
|
{
|
2020-07-15 18:17:39 +02:00
|
|
|
QString str;
|
2020-05-08 00:08:57 +02:00
|
|
|
str += QString::number(margins.left());
|
|
|
|
str += ";";
|
|
|
|
str += QString::number(margins.top());
|
|
|
|
str += ";";
|
|
|
|
str += QString::number(margins.right());
|
|
|
|
str += ";";
|
|
|
|
str += QString::number(margins.bottom());
|
|
|
|
|
|
|
|
return str;
|
|
|
|
}
|
|
|
|
|
2020-07-15 18:02:11 +02:00
|
|
|
/**
|
|
|
|
@brief QETUtils::marginsFromString
|
|
|
|
@param string
|
|
|
|
@return QMargins margins
|
|
|
|
*/
|
2020-05-08 00:08:57 +02:00
|
|
|
QMargins QETUtils::marginsFromString(const QString &string)
|
|
|
|
{
|
|
|
|
QMargins margins;
|
|
|
|
auto split = string.split(";");
|
|
|
|
if (split.size() != 4)
|
|
|
|
return margins;
|
|
|
|
|
|
|
|
margins.setLeft (split.at(0).toInt());
|
|
|
|
margins.setTop (split.at(1).toInt());
|
|
|
|
margins.setRight (split.at(2).toInt());
|
|
|
|
margins.setBottom(split.at(3).toInt());
|
|
|
|
|
|
|
|
return margins;
|
|
|
|
}
|
2022-01-03 21:01:25 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief QETUtils::graphicsHandlerSize
|
|
|
|
* @param item
|
|
|
|
* @return Return the handler size to use in the QGraphicsScene of @a item.
|
|
|
|
* If size can't be found, return 10 by default.
|
|
|
|
*/
|
|
|
|
qreal QETUtils::graphicsHandlerSize(QGraphicsItem *item)
|
|
|
|
{
|
|
|
|
if (const auto scene_ = item->scene())
|
|
|
|
{
|
|
|
|
if (!scene_->views().isEmpty())
|
|
|
|
{
|
|
|
|
if (const auto editor_ = QETApp::instance()->diagramEditorAncestorOf(scene_->views().at(0)))
|
|
|
|
{
|
|
|
|
const auto variant_ = editor_->property("graphics_handler_size");
|
|
|
|
//If variant_ can't be converted to qreal, the returned qreal is 0.0
|
|
|
|
//it's sufficient for us to check if value is set or not.
|
|
|
|
if (const auto value_ = variant_.toReal())
|
|
|
|
return value_;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
//Default value
|
|
|
|
return 10;
|
|
|
|
}
|