File: mapfunc.f

package info (click to toggle)
vis5d 4.3-5
  • links: PTS
  • area: main
  • in suites: slink
  • size: 16,856 kB
  • ctags: 6,127
  • sloc: ansic: 66,158; fortran: 4,470; makefile: 1,683; tcl: 414; sh: 69
file content (52 lines) | stat: -rw-r--r-- 1,664 bytes parent folder | download | duplicates (3)
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
C mapfunc.f
C
C VIS-5D version 3.1 */
C
C vis5d program for visualizing five dimensional gridded data sets
C Copyright (C) 1990, 1991, 1992, 1993  Bill Hibbard, Brian Paul,
C Dave Santek, and Andre Battaiola.
C
C This program is free software; you can redistribute it and/or modify
C it under the terms of the GNU General Public License as published by
C the Free Software Foundation; either version 1, or (at your option)
C any later version.
C
C This program is distributed in the hope that it will be useful,
C but WITHOUT ANY WARRANTY; without even the implied warranty of
C MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
C GNU General Public License for more details.
C
C You should have received a copy of the GNU General Public License
C along with this program; if not, write to the Free Software
C Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
C
C
C     FORTRAN subroutine to transform map line vertices.  This is
C     called from the newmap.c program.
C
C
      SUBROUTINE TRANSFORM( OLDLAT, OLDLON, NEWLAT, NEWLON )
C     Input/Output arguments are in degrees:
      REAL*4 OLDLAT, OLDLON, NEWLAT, NEWLON

C     Some local variables:
      REAL*4 LAT, LON, LAT2, LON2, ANGLE

C     Example:  Rotate a map by 10 degrees clockwise about an origin
C     in Wisconsin.

C     Move Wisconsin to origin:
      LAT = OLDLAT - 43.0
      LON = OLDLON - 90.0

C     Rotate by 10 degrees:
      ANGLE = 10 * 3.14159 / 180.0
      LAT2 = LON * SIN(ANGLE) + LAT * COS(ANGLE)
      LON2 = LON * COS(ANGLE) - LAT * SIN(ANGLE)

C     Translate back to Wisconsin
      NEWLAT = LAT2 + 43.0
      NEWLON = LON2 + 90.0

      RETURN
      END