mirror of
https://github.com/qelectrotech/qelectrotech-source-mirror.git
synced 2025-12-23 02:10:52 +01:00
Implementation d'un nouvel algorithme de modification des conducteurs
git-svn-id: svn+ssh://svn.tuxfamily.org/svnroot/qet/qet/trunk@125 bfdf4180-ca20-0410-9c96-a3a8aa849046
This commit is contained in:
92
conducerprofile.cpp
Normal file
92
conducerprofile.cpp
Normal file
@@ -0,0 +1,92 @@
|
||||
#include "conducerprofile.h"
|
||||
#include "conducer.h"
|
||||
#include "conducersegmentprofile.h"
|
||||
|
||||
/// Constructeur
|
||||
ConducerProfile::ConducerProfile() {
|
||||
}
|
||||
|
||||
/**
|
||||
Constructeur
|
||||
@param Conducer conducteur dont il faut extraire le profil
|
||||
*/
|
||||
ConducerProfile::ConducerProfile(Conducer *conducer) {
|
||||
foreach(ConducerSegment *conducer_segment, conducer -> segmentsList()) {
|
||||
segments << new ConducerSegmentProfile(conducer_segment);
|
||||
}
|
||||
beginOrientation = conducer -> terminal1 -> orientation();
|
||||
endOrientation = conducer -> terminal2 -> orientation();
|
||||
}
|
||||
|
||||
/// destructeur
|
||||
ConducerProfile::~ConducerProfile() {
|
||||
}
|
||||
|
||||
/// @return true si le profil est nul
|
||||
bool ConducerProfile::isNull() const {
|
||||
return(segments.isEmpty());
|
||||
}
|
||||
|
||||
/// @return la largeur occupee par le conducteur
|
||||
qreal ConducerProfile::width() const {
|
||||
qreal width = 0.0;
|
||||
foreach(ConducerSegmentProfile *csp, segments) {
|
||||
if (csp -> isHorizontal) width += csp -> length;
|
||||
}
|
||||
return(width);
|
||||
}
|
||||
|
||||
/// @return la hauteur occupee par le conducteur
|
||||
qreal ConducerProfile::height() const{
|
||||
qreal height = 0.0;
|
||||
foreach(ConducerSegmentProfile *csp, segments) {
|
||||
if (!csp -> isHorizontal) height += csp -> length;
|
||||
}
|
||||
return(height);
|
||||
}
|
||||
|
||||
/**
|
||||
@param type Type de Segments
|
||||
@return Le nombre de segments composant le conducteur.
|
||||
*/
|
||||
uint ConducerProfile::nbSegments(QET::ConducerSegmentType type) const {
|
||||
if (type == QET::Both) return(segments.count());
|
||||
uint nb_seg = 0;
|
||||
foreach(ConducerSegmentProfile *csp, segments) {
|
||||
if (type == QET::Horizontal && csp -> isHorizontal) ++ nb_seg;
|
||||
else if (type == QET::Vertical && !csp -> isHorizontal) ++ nb_seg;
|
||||
}
|
||||
return(nb_seg);
|
||||
}
|
||||
|
||||
/// @return les segments horizontaux de ce profil
|
||||
QList<ConducerSegmentProfile *> ConducerProfile::horizontalSegments() {
|
||||
QList<ConducerSegmentProfile *> segments_list;
|
||||
foreach(ConducerSegmentProfile *csp, segments) {
|
||||
if (csp -> isHorizontal) segments_list << csp;
|
||||
}
|
||||
return(segments_list);
|
||||
}
|
||||
|
||||
/// @return les segments verticaux de ce profil
|
||||
QList<ConducerSegmentProfile *> ConducerProfile::verticalSegments() {
|
||||
QList<ConducerSegmentProfile *> segments_list;
|
||||
foreach(ConducerSegmentProfile *csp, segments) {
|
||||
if (!csp -> isHorizontal) segments_list << csp;
|
||||
}
|
||||
return(segments_list);
|
||||
}
|
||||
|
||||
/**
|
||||
Permet de debugger un profil de conducteur
|
||||
@param d Object QDebug a utiliser pour l'affichage des informations de debug
|
||||
@param t Profil de conducteur a debugger
|
||||
*/
|
||||
QDebug &operator<<(QDebug d, ConducerProfile &t) {
|
||||
d << "ConducerProfile {";
|
||||
foreach(ConducerSegmentProfile *csp, t.segments) {
|
||||
d << "CSP" << (csp -> isHorizontal ? "horizontal" : "vertical") << ":" << csp -> length << ",";
|
||||
}
|
||||
d << "}";
|
||||
return(d.space());
|
||||
}
|
||||
Reference in New Issue
Block a user