added qra conversions and heading/distance calculations
[spider.git] / cmd / show / heading.pl
1 #
2 # show the dxcc number for each callsign or prefix entered
3 #
4 # $Id$
5 #
6
7 my ($self, $line) = @_;
8 my @list = split /\s+/, $line;                # generate a list of callsigns
9
10 my $l;
11 my @out;
12 my $lat = $self->user->lat;
13 my $long = $self->user->long;
14 if (!$long && !$lat) {
15         push @out, $self->msg('heade1');
16         $lat = $main::mylat;
17         $long = $main::mylong;
18 }
19
20 foreach $l (@list) {
21   my @ans = Prefix::extract($l);
22   next if !@ans;
23   my $pre = shift @ans;
24   my $a;
25   foreach $a (@ans) {
26           my ($b, $dx) = DXBearing::bdist($lat, $long, $a->{lat}, $a->{long});
27           my ($r, $rdx) = DXBearing::bdist($a->{lat}, $a->{long}, $lat, $long);
28           push @out, sprintf "%-9s (%s, %s) Bearing: %.0f Recip: %.0f %.0fKm %.0fMi", uc $l, $pre, $a->name(), $b, $r, $dx, $dx * 0.62133785;
29           $l = "";
30   }
31 }
32
33 return (1, @out);