|
| 1 | +#define ACCEPT_USE_OF_DEPRECATED_PROJ_API_H |
| 2 | +#include <proj_api.h> |
| 3 | +#include "qtproj.h" |
| 4 | + |
| 5 | +QtProj::QtProj(QWidget *parent) : QMainWindow(parent) |
| 6 | +{ |
| 7 | + ui.setupUi(this); |
| 8 | + connect(ui.actionTransfer,SIGNAL(triggered()),this,SLOT(slot_transfer())); |
| 9 | +} |
| 10 | + |
| 11 | +QtProj::~QtProj() |
| 12 | +{ |
| 13 | + |
| 14 | +} |
| 15 | + |
| 16 | +void QtProj::slot_transfer() |
| 17 | +{ |
| 18 | + int flag, digits = 8; |
| 19 | + double lat, lon, height; |
| 20 | + QString qsSrc, qsDst; |
| 21 | + projPJ src, dst; |
| 22 | + |
| 23 | + //TODO: need check |
| 24 | + lat = ui.le_srcLat->text().toDouble(); |
| 25 | + lon = ui.le_srcLon->text().toDouble(); |
| 26 | + height = ui.le_srcH->text().toDouble(); |
| 27 | + //e.g. |
| 28 | + //double lat=41.44; |
| 29 | + //double lon=103.33; |
| 30 | + //double height=500; |
| 31 | + |
| 32 | + qsSrc = ui.le_srcCS->text(); |
| 33 | + qsDst = ui.le_dstCS->text(); |
| 34 | + // e.g. |
| 35 | + // QString qsSrc = "+proj=longlat +datum=WGS84 +no_defs"; |
| 36 | + // QString qsDst = "+proj=tmerc +lat_0=0 +lon_0=105 +k=1 +x_0=18500000 +y_0=0 +ellps=krass +units=m +no_defs +towgs84=0,0,0,0,0,0,0"; |
| 37 | + |
| 38 | + src = pj_init_plus(qsSrc.toStdString().c_str()); |
| 39 | + dst = pj_init_plus(qsDst.toStdString().c_str()); |
| 40 | + |
| 41 | + if (src == NULL || dst == NULL) |
| 42 | + { |
| 43 | + ui.le_dstLat->setText(QString("Error")); |
| 44 | + if (src == NULL) |
| 45 | + ui.le_dstLon->setText(QString("Bad Src cs")); |
| 46 | + if (dst == NULL) |
| 47 | + ui.le_dstH->setText(QString("Bad Dst cs")); |
| 48 | + return; |
| 49 | + } |
| 50 | + |
| 51 | + if ((qsSrc.contains("+proj=longlat", Qt::CaseInsensitive)) || (qsSrc.contains("+proj=latlong", Qt::CaseInsensitive))) |
| 52 | + { |
| 53 | + lon *= DEG_TO_RAD; |
| 54 | + lat *= DEG_TO_RAD; |
| 55 | + } |
| 56 | + |
| 57 | + flag = pj_transform(src, dst, 1, 1, &lon, &lat, &height); |
| 58 | + |
| 59 | + pj_free(src); |
| 60 | + pj_free(dst); |
| 61 | + |
| 62 | + if (flag == 0) |
| 63 | + { |
| 64 | + if ((qsDst.contains("+proj=longlat", Qt::CaseInsensitive)) || (qsDst.contains("+proj=latlong", Qt::CaseInsensitive))) |
| 65 | + { |
| 66 | + lon /= DEG_TO_RAD; |
| 67 | + lat /= DEG_TO_RAD; |
| 68 | + } |
| 69 | + else |
| 70 | + { |
| 71 | + digits = 3; |
| 72 | + } |
| 73 | + |
| 74 | + ui.le_dstLat->setText(QString::number(lat, 'f', digits)); |
| 75 | + ui.le_dstLon->setText(QString::number(lon, 'f', digits)); |
| 76 | + ui.le_dstH->setText(QString::number(height, 'f', digits)); |
| 77 | + } |
| 78 | + else |
| 79 | + { |
| 80 | + ui.le_dstLat->setText(QString("Error")); |
| 81 | + ui.le_dstLon->setText(QString::number(flag, 'd', 2)); |
| 82 | + ui.le_dstH->setText(QString("Error")); |
| 83 | + } |
| 84 | +} |
0 commit comments