plc-user c7ed744481 Include some fonts to QElectroTech
- include Liberation-Fonts and osifont
  (thanks elevatormind!)
- use "Liberation Sans" as default-font
- adjust License-Tab in About-Form
- Bugfix: When selecting a font, the current
  font is highlighted in dialog
- adjust some whitespace and English comments
2025-05-18 14:15:20 +02:00

230 lines
7.9 KiB
C++

/*
Copyright 2006-2025 The QElectroTech Team
This file is part of QElectroTech.
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.
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.
You should have received a copy of the GNU General Public License
along with QElectroTech. If not, see <http://www.gnu.org/licenses/>.
*/
#ifndef _QET_H
#define _QET_H
#include <QDomElement>
#include <QFile>
#include <QObject>
class QActionGroup;
/**
This file provides useful functions and enums that may be used from
anywhere else within the QElectroTech application.
*/
namespace QET {
QString license(); // only QETs license
std::tuple<QString, QString> licenses(const QString &); // all licenses
//Describe the current state of a graphic item
enum GraphicsItemState {
GIOK, ///<General state
GIBuildingFromXml, ///<Item is currently building from a xml description (element)
GILoadingFromXml ///<Item is loading her properties from a xml description.
};
/// List the various kind of changes for the zValue
enum DepthOption {
BringForward, ///< Bring item to the foreground so they have the highest zValue
Raise, ///< Raise item one layer above their current one; zValues are incremented
Lower, ///< Send item one layer below their current one; zValues are decremented
SendBackward ///< Send item to the background so they have the lowest zValue
};
/// Oriented movements
enum OrientedMovement {
ToNorth,
ToNorthEast,
ToEast,
ToSouthEast,
ToSouth,
ToSouthWest,
ToWest,
ToNorthWest
};
/// List areas related to some common operations
enum OperationAreas {
ChangeInnerPoints = -4,
RotateArea = -3,
MoveArea = -2,
NoOperation = -1,
ResizeFromTopLeftCorner = 0,
ResizeFromTopCenterCorner = 1,
ResizeFromTopRightCorner = 2,
ResizeFromMiddleLeftCorner = 3,
ResizeFromMiddleRightCorner = 4,
ResizeFromBottomLeftCorner = 5,
ResizeFromBottomCenterCorner = 6,
ResizeFromBottomRightCorner = 7
};
/// Supported types of interactive scaling, typically for a single element primitive
enum ScalingMethod {
FreeScaling, ///< do not interfere with the default scaling process
SnapScalingPointToGrid, ///< snap the point used to define the new bounding rectangle to the grid
RoundScaleRatios ///< adjust the scaling movement so that the induced scaling ratios are rounded
};
/// Known kinds of conductor segments
enum ConductorSegmentType {
Horizontal = 1, ///< Horizontal segment
Vertical = 2, ///< Vertical segment
Both = 3 ///< Invalid segment
};
/**
This enums lists the various kind of items users can manage within the
application.
*/
enum ItemType {
Element = 1,
ElementsCategory = 2,
ElementsCollection = 4,
ElementsContainer = 6,
ElementsCollectionItem = 7,
TitleBlockTemplate = 8,
TitleBlockTemplatesCollection = 16,
TitleBlockTemplatesCollectionItem = 24,
Diagram = 32,
Project = 64,
All = 127
};
/**
This enum represents the various steps when applying a filter.
*/
enum Filtering {
BeginFilter,
RegularFilter,
EndFilter
};
/**
This enums lists the various ways to handle a standard problem when copying
or moving element items (collections, categories, elements).
@see MoveElementsHandler
*/
enum Action {
Retry, ///< The operation must be tried again
Ignore, ///< Skip the current item
Erase, ///< Erase the target content
Abort, ///< abort the whole operation, ignoring the current item
Managed, ///< the current item was handled by the Strategy object: do not treat it and continue
Rename ///< the target has to be renamed
};
/**
This enum represents diagram areas that may be exported/printed.
*/
enum DiagramArea {
BorderArea, ///< Export the diagram along with its border and title block
ElementsArea ///< Export the content of the diagram only
};
/// enum used to specify the type of a length
enum TitleBlockColumnLength {
Absolute, ///< the length is absolute and should be applied as is
RelativeToTotalLength, ///< the length is just a fraction of the total available length
RelativeToRemainingLength ///< the length is just a fraction of the length that is still available when other types of lengths have been removed
};
///Enum used to specify the origin of a collection of thing (title block, element etc...)
enum QetCollection {
Common, ///< From common collection
Company, ///< From company collection
Custom, ///< From user collection
Embedded ///< From an embedded collection (a project for example)
};
QString qetCollectionToString (const QetCollection &c);
QetCollection qetCollectionFromString (const QString &str);
bool lineContainsPoint(const QLineF &, const QPointF &);
bool orthogonalProjection(const QPointF &, const QLineF &, QPointF * = nullptr);
bool attributeIsAnInteger(const QDomElement &, const QString& , int * = nullptr);
bool attributeIsAReal(const QDomElement &, const QString& , qreal * = nullptr);
QString ElementsAndConductorsSentence(int elements=0,
int conductors=0,
int indi_texts=0,
int images=0,
int shapes=0,
int element_text=0,
int tables_count=0,
int terminal_strip_count=0);
QList<QDomElement> findInDomElement(const QDomElement &, const QString &);
QList<QDomElement> findInDomElement(const QDomElement &, const QString &, const QString &);
QList<QChar> forbiddenCharacters();
QString stringToFileName(const QString &);
QString escapeSpaces(const QString &);
QString unescapeSpaces(const QString &);
QString joinWithSpaces(const QStringList &);
QStringList splitWithSpaces(const QString &);
QString diagramAreaToString(const QET::DiagramArea &);
QET::DiagramArea diagramAreaFromString(const QString &);
qreal round(qreal, qreal);
qreal correctAngle(const qreal &, const bool &positive = false);
bool compareCanonicalFilePaths(const QString &, const QString &);
bool writeXmlFile(QDomDocument &xml_doc, const QString &filepath, QString * error_message= nullptr);
bool writeToFile (QDomDocument &xml_doc, QFile *file, QString *error_message = nullptr);
bool eachStrIsEqual (const QStringList &qsl);
QActionGroup *depthActionGroup(QObject *parent = nullptr);
}
Q_DECLARE_METATYPE(QET::DepthOption)
class Qet : public QObject
{
Q_OBJECT
public:
///This enum lists the various available endings for line primitives when drawing an electrical element.
enum EndType {
None, ///< Regular line
Simple, ///< Base-less triangle
Triangle, ///< Triangle
Circle, ///< Circle
Diamond ///< Diamond
};
Q_ENUM (EndType)
static QString endTypeToString(const Qet::EndType &);
static Qet::EndType endTypeFromString(const QString &);
/// Orientation (used for electrical elements and their terminals)
enum Orientation {North,
East,
South,
West};
Q_ENUM (Orientation)
static Qet::Orientation nextOrientation(Qet::Orientation);
static Qet::Orientation previousOrientation(Qet::Orientation);
static Qet::Orientation orientationFromString (const QString &);
static QString orientationToString (Qet::Orientation);
static bool surLeMemeAxe (Qet::Orientation, Qet::Orientation);
static bool isOpposed (Qet::Orientation a, Qet::Orientation b);
static bool isHorizontal (Qet::Orientation);
static bool isVertical (Qet::Orientation);
};
#endif