banniere

Le portail francophone de la géomatique


Toujours pas inscrit ? Mot de passe oublié ?
Nom d'utilisateur    Mot de passe              Toujours pas inscrit ?   Mot de passe oublié ?

Annonce

Rencontres QGIS 2025

L'appel à participation est ouvert jusqu'au 19 janvier 2025!

#1 Wed 13 July 2011 10:51

mario002e
Participant occasionnel
Date d'inscription: 7 Jul 2011
Messages: 11

Convertir les données géométriques en données géographiques

Bonjour!
Je suis sur un projet de test afin de cerner les outils de géolocalisation. Mais étant néophyte, quelques notions en postGIS m'échappent.
Voici mon problème:
Le SRID utilisé est le 4326.
J'ai 3 champs: Le champ geocenter dans lequel je stocke les points, centres de mes cercles, le champ georadius dans lequel je stocke les rayons des cercles et le champ geocircle dans lequel sont stockés les cercles qui ne sont en fait que des polygones.
En utilisant la fonction ST_Buffer, je remarque que certains des sommets de mes polygones (cercle) dépassent l'intervalle [-180 -90, 180 90].
Mon souci, c'est de calculer la distance d'un point extérieur au cercle par rapport au cercle. En utilisant ST_Distance sur ces polygones de types géométriques, je constate que la distance calculée est fausse. J'ai pensé alors utilisé un cast mais je rencontre cette erreur: Coordinate values are out of range [-180 -90, 180 90] for GEOGRAPHY type.
S'il vous plait, il y a-t-il un moyen de convertir ces données géométriques en données géographiques quoique les points sont hors l'intervalle [-180 -90, 180 90]?
Merci

Hors ligne

 

#2 Wed 13 July 2011 11:28

mario002e
Participant occasionnel
Date d'inscription: 7 Jul 2011
Messages: 11

Re: Convertir les données géométriques en données géographiques

J'ai trouvé: En fait, je ne savais qu'il y avait une surcharge de la méthode ST_Buffer pour les données de types géographiques! Il fallait donc utiliser ST_Buffer(geography, double) au lieu de ST_Buffer(geometry, double)
Merci

Hors ligne

 

Pied de page des forums

Powered by FluxBB