File: pj_obs_api_mini_demo.pl

package info (click to toggle)
libgeo-libproj-ffi-perl 1.01-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 304 kB
  • sloc: perl: 1,339; makefile: 11
file content (58 lines) | stat: -rwxr-xr-x 1,640 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
#! /usr/bin/env perl

use strict;
use warnings;
use Geo::LibProj::FFI 0.05 qw( :all );


# Please compare this example code with:
# https://github.com/OSGeo/PROJ/blob/8.0/examples/pj_obs_api_mini_demo.c
# See also:
# https://proj.org/development/quickstart.html


my $C;          # PJ_CONTEXT*
my $P;          # PJ*
my $P_for_GIS;  # PJ*
my ($a, $b);    # PJ_COORD

# or you may set $C=PJ_DEFAULT_CTX if you are sure you will
# use PJ objects from only one thread
$C = proj_context_create();

$P = proj_create_crs_to_crs( $C,
                             "EPSG:4326",
                             "+proj=utm +zone=32 +datum=WGS84",  # or EPSG:32632
                             undef );

unless ($P) {
	printf STDERR "Oops\n";
	exit 1;
}

# This will ensure that the order of coordinates for the input CRS
# will be longitude, latitude, whereas EPSG:4326 mandates latitude,
# longitude
$P_for_GIS = proj_normalize_for_visualization($C, $P);
unless ($P_for_GIS) {
	printf STDERR "Oops\n";
	exit 1;
}
proj_destroy($P);
$P = $P_for_GIS;

# a coordinate union representing Copenhagen: 55d N, 12d E
# Given that we have used proj_normalize_for_visualization(), the order of
# coordinates is longitude, latitude, and values are expressed in degrees.
$a = proj_coord( 12, 55, 0, 0 );

# transform to UTM zone 32, then back to geographical
$b = proj_trans( $P, PJ_FWD, $a );
printf "easting: %.3f, northing: %.3f\n", $b->enu_e, $b->enu_n;
$b = proj_trans( $P, PJ_INV, $b );
printf "longitude: %g, latitude: %g\n", $b->lp_lam, $b->lp_phi;

# Clean up
proj_destroy($P);
proj_context_destroy($C);  # may be omitted in the single threaded case
exit 0;