aboutsummaryrefslogtreecommitdiff
path: root/sys/gio/nspp/portlib/pwrit.f
blob: 56ed0fb24f751033904e0d3e0568f4601734f7f2 (plain) (blame)
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
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
subroutine pwrit (x,y,ichar,nchar,isize,ioren,icent)
      common /sysplt/ mmajx  ,mmajy  ,mminx  ,mminy  ,mxlab  ,mylab  ,
     1                mflg   ,mtype  ,mxa    ,mya    ,mxb    ,myb    ,
     2                mx     ,my     ,mtypex ,mtypey ,xxa    ,yya    ,
     3                xxb    ,yyb    ,xxc    ,yyc    ,xxd    ,yyd    ,
     4                xfactr ,yfactr ,xadd   ,yadd   ,xx     ,yy     ,
     5                mfmtx(3)       ,mfmty(3)       ,mumx   ,mumy   ,
     6                msizx  ,msizy  ,mxdec  ,mydec  ,mxor   ,mop(19),
     7                mname(19)      ,mxold  ,myold  ,mxmax  ,mymax  ,
     8                mxfac  ,myfac  ,modef  ,mf2er  ,mshftx ,mshfty ,
     9                mmgrx  ,mmgry  ,mmnrx  ,mmnry  ,mfrend ,mfrlst ,
     +                mcrout ,mpair1 ,mpair2 ,msblen ,mflcnt ,mjxmin ,
     1                mjymin ,mjxmax ,mjymax ,mnxsto ,mnysto ,mxxsto ,
     2                mxysto ,mprint ,msybuf(360)    ,mncpw  ,minst  ,
     3                mbufa  ,mbuflu ,mfwa(12)       ,mlwa(12)       ,
     4                mipair ,mbprs(16)      ,mbufl  ,munit  ,mbswap ,
     5                small
c     ray bovet patch to avoid small integers being set to 0
      integer x,y,xx,yy
c
      dimension       ichar(nchar)
      dimension       iwide(4)
      data wide,high,white /6.,7.,2./
      data iwide(1),iwide(2),iwide(3),iwide(4)/256,384,512,768/
c
c copy parameters into local variables
c
      kchar = nchar
      ksize = isize
      koren = ioren
c
c transform character size into metacode units.
c
      if (ksize .gt. 3) ksize = ishift(ksize,mshftx)
      if (ksize .le. 3) ksize = iwide(ksize+1)
      call optn (4hcsiz,ksize)
c
c transform orientation.
c
      if (koren .lt. 0) koren = koren+360
      if (koren .ge. 0) call optn (4horen,koren)
c
c pass on centering.
c
      call optn (4hcent,max0(0,min0(2,icent+1)))
c
c make coordinates global.
c
      xx = x
      yy = y
      call trans
c
c use real variables for convenience.
c
      fmx = mx
      fmy = my
c
c work with radians instead of degrees.
c 2*pi/360. approximately = .0174533
c
      angle = float(koren)*.0174533
c
c find starting point for string when considering centering option.
c
      cosa = cos(angle)
      sina = sin(angle)
      wide2 = ksize/2
      widen = float(ksize*kchar)-float(ksize)*white/wide
      if (icent) 103,101,102
  101 fmx = fmx-cosa*widen*.5
      fmy = fmy-sina*widen*.5
      go to 103
  102 fmx = fmx-cosa*widen
      fmy = fmy-sina*widen
  103 continue
      hgt2 = (3*ksize)/4
      nxul = fmx-cosa*wide2-sina*hgt2
      nyul = fmy+cosa*hgt2-sina*wide2
      nxll = fmx-cosa*wide2+sina*hgt2
      nyll = fmy-cosa*hgt2-sina*wide2
      nxur = fmx+cosa*widen+cosa*wide2-sina*hgt2
      nyur = fmy+sina*widen+cosa*hgt2+sina*wide2
      nxlr = fmx+cosa*widen+cosa*wide2+sina*hgt2
      nylr = fmy+sina*widen-cosa*hgt2+sina*wide2
      mjxmax = min0(32767,max0(mjxmax,nxul,nxll,nxur,nxlr))
      mjxmin = max0(0,min0(mjxmin,nxul,nxll,nxur,nxlr))
      mjymax = min0(32767,max0(mjymax,nyul,nyll,nyur,nylr))
      mjymin = max0(0,min0(mjymin,nyul,nyll,nyur,nylr))
      minst = 0
      call put42
      call putins (33,ichar,kchar)
      mxold = -9999
      myold = -9999
      return
      end