2008-04-11 10:11:29 +02:00
|
|
|
#include "area.hh"
|
|
|
|
|
|
|
|
|
2008-05-29 10:48:05 +02:00
|
|
|
|
|
|
|
Area::Area(const string &_name, const float &_x1, const float &_x2, const float &_y1, const float &_y2, const float &_z1, const float &_z2)
|
2008-04-11 10:11:29 +02:00
|
|
|
{
|
2008-05-29 10:48:05 +02:00
|
|
|
area_name = _name ;
|
2008-07-03 15:04:30 +02:00
|
|
|
|
|
|
|
if (_x1 < _x2 && _y1 > _y2) // Le premier point de la pièce est en haut à gauche
|
|
|
|
{
|
|
|
|
x_min = _x1 ;
|
|
|
|
x_max = _x2 ;
|
|
|
|
y_min = _y2 ; // on inverse les Y
|
|
|
|
y_max = _y1 ;
|
|
|
|
}
|
|
|
|
|
|
|
|
else if (_x1 > _x2 && _y1 < _y2) // Le premier point de la pièce est en bas à droite
|
|
|
|
{
|
|
|
|
x_min = _x2 ; // on inverse les X
|
|
|
|
x_max = _x1 ;
|
|
|
|
y_min = _y1 ;
|
|
|
|
y_max = _y2 ;
|
|
|
|
}
|
|
|
|
|
|
|
|
else if (_x1 > _x2 && _z1 > _z2) // Le premier point de la pièce est en haut à droite
|
|
|
|
{
|
|
|
|
x_min = _x2 ; // on inverse les X
|
|
|
|
x_max = _x1 ;
|
|
|
|
z_min = _z2 ; // on inverse les Y
|
|
|
|
z_max = _z1 ;
|
|
|
|
}
|
|
|
|
|
|
|
|
else // Le premier point de la pièce est en bas à gauche ou autres cas (par ex. coordonnées nulles)
|
|
|
|
{
|
|
|
|
x_min = _x1 ;
|
|
|
|
x_max = _x2 ;
|
|
|
|
y_min = _y1 ;
|
|
|
|
y_max = _y2 ;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (_z1 < _z2)
|
|
|
|
{
|
|
|
|
z_min = _z1 ;
|
|
|
|
z_max = _z2 ;
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
z_min = _z2 ;
|
|
|
|
z_max = _z1 ;
|
|
|
|
}
|
|
|
|
|
|
|
|
#ifdef DEBUG_2
|
|
|
|
cout << "Area créée ("<< area_name << ',' << x_min << ',' << y_min << ',' << x_max << ',' << y_max << ',' << z_min << ',' << z_max << ")" << endl ;
|
|
|
|
#endif // DEBUG_2
|
2008-04-11 10:11:29 +02:00
|
|
|
}
|
|
|
|
|
2008-05-29 10:48:05 +02:00
|
|
|
|
|
|
|
|
2008-04-11 10:11:29 +02:00
|
|
|
Area::Area(const Area &a)
|
|
|
|
{
|
2008-04-15 12:19:15 +02:00
|
|
|
area_name = a.area_name;
|
|
|
|
x_min = a.x_min;
|
|
|
|
x_max = a.x_max;
|
|
|
|
y_min = a.y_min;
|
|
|
|
y_max = a.y_max;
|
|
|
|
z_min = a.z_min;
|
|
|
|
z_max = a.z_max;
|
2008-04-11 10:11:29 +02:00
|
|
|
}
|
|
|
|
|
2008-05-29 10:48:05 +02:00
|
|
|
|
|
|
|
|
|
|
|
bool Area::containsPoint(const Point &p)const
|
2009-05-29 13:46:49 +02:00
|
|
|
{
|
Incorporation de la dernière version de Julien
Extrait de son courriel :
« Par rapport à la précédente j'ai surtout corrigé des bugs. »
Note : la version du listener portable sur Fonera, envoyée en même temps
par Julien, viendra plus tard (le temps que je l'incorpore).
Détail des changements après analyse du code :
aggregator : correction de bogues.
positioning :
* Ajout d'un fichier de config format boost (cfg/config.cfg).
* Makefile : implantation des cibles "install" et "uninstall" ; la cible
"astyle" devient "style".
* accesspoint.{hh,cc}, area.cc, measurement.hh, point.{hh,cc},
referencepoint.{hh,cc} : cosmétique.
* owlps-positioning.c : correction de la lecture du fichier de config
(ajout d'une option permettant de spécifier un fichier alternatif).
* server.cc : essentiellement correction des requêtes.
* libowlps-positioning.{hh,cc} : passage de "unsigned long long" à
"uint64_t" comme type de retour de timeval_to_ms().
writeInDb :
* Ajout de la gestion d'un fichier de config.
* Ajout de deux scripts pour la BDD.
git-svn-id: https://pif.pu-pm.univ-fcomte.fr/svn/loc@96 785a6c6c-259e-4ff1-8b91-dc31627914f0
2009-07-01 15:39:58 +02:00
|
|
|
if (p.getX() >= x_min &&
|
|
|
|
p.getX() <= x_max &&
|
|
|
|
p.getY() >= y_min &&
|
|
|
|
p.getY() <= y_max &&
|
|
|
|
p.getZ() >= z_min &&
|
|
|
|
p.getZ() <= z_max
|
|
|
|
)
|
2009-05-29 13:46:49 +02:00
|
|
|
return true;
|
|
|
|
|
|
|
|
return false;
|
|
|
|
}
|
2008-05-29 10:48:05 +02:00
|
|
|
|
|
|
|
|
|
|
|
|
GuiNuMo : gestion topologie
server.{hh,cc} :
* Utilisation d'une map plutôt que d'une multimap pour stocker la liste
des pièces. Conséquence : les noms des zones doivent être uniques, il
faut donc numéroter les zones des pièces composites (par exemple
« Couloir N1 A » et « Couloir N1 B »).
* Ajout de la fonction inWhichAreas() qui permet d'obtenir la liste des
zones auxquelles appartient un point.
* Modification de la fonction makeWaypointDistancesFromFile() (renommée
makeWaypointListFromFile()) de manière à ce qu'elle calcule la matrice
des distances entre points de passage (lecture d'une liste de points).
Abandon du format décrivant les points en visibilité (voir le fichier
cfg/distances.csv, supprimé à cette révision), puisque nous nous
servons des points de passage et de la description des zones pour
calculer les liens entre points. RESTE À FAIRE : prise en comppte de
la topologie dans le calcul de distance.
* Ajout de deux fonctions areaConnection() qui permettent de récupérer
la liste des points de passage d'une zone, ou faisant l'intersection
entre deux zones.
* Ajout de la fonction distanceTopology, qui calcule la distance entre
deux points en tenant compte de la topologie (zones et points de
passage entre elles).
* Ajout de la fonction makeReferencePointDistances(), qui calcule les
distances entre points de référence, en tenant compte de la
topologie.
* Ajout de la fonction point_vector_idx(), semblable à point_tab_idx()
mais pour un vector<Point>.
referencepoint.{hh,cc} :
* Ajout de l'operator de cast en Point (operator Point()).
area.{hh,cc} :
* Ajout de l'operator==(Area).
cfg/distances.csv
* Suppression de ce fichier obsolète.
git-svn-id: https://pif.pu-pm.univ-fcomte.fr/svn/loc@47 785a6c6c-259e-4ff1-8b91-dc31627914f0
2008-06-25 16:19:07 +02:00
|
|
|
bool Area::operator==(const Area &a)const
|
2009-05-29 13:46:49 +02:00
|
|
|
{
|
|
|
|
if (area_name == a.area_name &&
|
|
|
|
x_min == a.x_min &&
|
|
|
|
x_max == a.x_max &&
|
|
|
|
y_min == a.y_min &&
|
|
|
|
y_max == a.y_max &&
|
|
|
|
z_min == a.z_min &&
|
|
|
|
z_max == a.z_max
|
|
|
|
)
|
|
|
|
return true ;
|
|
|
|
|
|
|
|
return false ;
|
|
|
|
}
|
GuiNuMo : gestion topologie
server.{hh,cc} :
* Utilisation d'une map plutôt que d'une multimap pour stocker la liste
des pièces. Conséquence : les noms des zones doivent être uniques, il
faut donc numéroter les zones des pièces composites (par exemple
« Couloir N1 A » et « Couloir N1 B »).
* Ajout de la fonction inWhichAreas() qui permet d'obtenir la liste des
zones auxquelles appartient un point.
* Modification de la fonction makeWaypointDistancesFromFile() (renommée
makeWaypointListFromFile()) de manière à ce qu'elle calcule la matrice
des distances entre points de passage (lecture d'une liste de points).
Abandon du format décrivant les points en visibilité (voir le fichier
cfg/distances.csv, supprimé à cette révision), puisque nous nous
servons des points de passage et de la description des zones pour
calculer les liens entre points. RESTE À FAIRE : prise en comppte de
la topologie dans le calcul de distance.
* Ajout de deux fonctions areaConnection() qui permettent de récupérer
la liste des points de passage d'une zone, ou faisant l'intersection
entre deux zones.
* Ajout de la fonction distanceTopology, qui calcule la distance entre
deux points en tenant compte de la topologie (zones et points de
passage entre elles).
* Ajout de la fonction makeReferencePointDistances(), qui calcule les
distances entre points de référence, en tenant compte de la
topologie.
* Ajout de la fonction point_vector_idx(), semblable à point_tab_idx()
mais pour un vector<Point>.
referencepoint.{hh,cc} :
* Ajout de l'operator de cast en Point (operator Point()).
area.{hh,cc} :
* Ajout de l'operator==(Area).
cfg/distances.csv
* Suppression de ce fichier obsolète.
git-svn-id: https://pif.pu-pm.univ-fcomte.fr/svn/loc@47 785a6c6c-259e-4ff1-8b91-dc31627914f0
2008-06-25 16:19:07 +02:00
|
|
|
|
|
|
|
|
|
|
|
|
2008-05-29 10:48:05 +02:00
|
|
|
ostream &operator<<(ostream &os, const Area &a)
|
|
|
|
{
|
|
|
|
os << a.area_name << ';' << a.x_min << ';' << a.x_max << ';' << a.y_min << ';' << a.y_max << ';' << a.z_min << ';' << a.z_max ;
|
|
|
|
return os ;
|
|
|
|
}
|