Trailing-Edge
-
PDP-10 Archives
-
decuslib20-02
-
decus/20-0049/dshplt.for
There is 1 other file named dshplt.for in the archive. Click here to see a list.
SUBROUTINE DSHPLT(XPOINT,YPOINT,KRDBGN,KRDEND,XFIRST,YFIRST,
1 XFINAL,YFINAL,XWIDTH,YWIDTH,XCORNR,YCORNR,RELHIT,RELSPC,
2 LASTX,LASTY)
C 09/18/67
C DASHED LINE DATA PLOTTING SUBROUTINE FOR GENPLT-II PLOT PACKAGE
C
C DONALD BARTH, C/O K.B. WIBERG, DEPT. OF CHEMISTRY, YALE UNIVERSITY
C
C SUBROUTINE DSHPLT ARGUMENT LIST DEFINITIONS.
C
C XPOINT = ARRAY OF X COORDINATES OF POINTS TO BE PLOTTED.
C YPOINT = ARRAY OF Y COORDINATES OF POINTS TO BE PLOTTED.
C KRDBGN = SUBSCRIPT OF FIRST POINT TO BE PLOTTED.
C KRDEND = SUBSCRIPT OF FINAL POINT TO BE PLOTTED.
C XFIRST = X COORDINATE TO BE PLACED AT LEFT BORDER OF PLOT AREA.
C YFIRST = Y COORDINATE TO BE PLACED AT LOWER BORDER OF PLOT AREA.
C XFINAL = Y COORDINATE TO BE PLACED AT RIGHT BORDER OF PLOT AREA.
C YFINAL = Y COORDINATE TO BE PLACED AT UPPER BORDER OF PLOT AREA.
C XWIDTH = HORIZONTAL WIDTH OF PLOT AREA.
C YWIDTH = VERTICAL HEIGHT OF PLOT AREA.
C XCORNR = X DISTANCE FROM PLOTTING TABLE ORIGIN TO LEFT PLOT EDGE.
C YCORNR = Y DISTANCE FROM PLOTTING TABLE ORIGIN TO LOWER PLOT EDGE.
C RELHIT = LENGTH OF DASHES IN UNITS OF MAGNITUDE 0.02*YWIDTH.
C RELSPC = LENGTH OF SPACES IN UNITS OF MAGNITUDE 0.02*YWIDTH.
C LASTX = LAST X GRID COORDINATE PLOTTED.
C LASTY = LAST Y GRID COORDINATE PLOTTED.
C
DIMENSION XPOINT(1000),YPOINT(1000)
COMMON/PPARM/FACTOR,OFSETX,OFSETY,IERR,IPEN,NTAPE,MODE,IPOINT,
1IFREER,ILINE
MODE = IFREER
XSCALE=FACTOR*XWIDTH/(XFINAL-XFIRST)
YSCALE=FACTOR*YWIDTH/(YFINAL-YFIRST)
XMIN=FACTOR*XCORNR + OFSETX
YMIN=FACTOR*YCORNR + OFSETY
XMAX=XMIN+(FACTOR*XWIDTH)
YMAX=YMIN+(FACTOR*YWIDTH)
DASH=RELHIT*FACTOR*YWIDTH/50.0
SPACE=RELSPC*FACTOR*YWIDTH/50.0
LINE=-1
THISX=XMIN+(XSCALE*(XPOINT(KRDBGN)-XFIRST))
THISY=YMIN+(YSCALE*(YPOINT(KRDBGN)-YFIRST))
KRD=KRDBGN
C
C ***********************ENTER PLOTTING LOOP************************
1 KRD=KRD+1
IF(KRD-KRDEND)2,2,32
2 THATX=THISX
THATY=THISY
THISX=XMIN+(XSCALE*(XPOINT(KRD)-XFIRST))
THISY=YMIN+(YSCALE*(YPOINT(KRD)-YFIRST))
STARTX=THATX
HALTX=THISX
DISTX=THISX-THATX
DISTY=THISY-THATY
C
C *******************TEST HORIZONTAL COORDINATES********************
IF(STARTX-XMIN)3,4,4
3 STARTX=XMIN
LINE=-1
IF(HALTX-XMIN)1,8,8
4 IF(STARTX-XMAX)6,6,5
5 STARTX=XMAX
LINE=-1
IF(HALTX-XMAX)6,6,1
6 IF(HALTX-XMIN)7,8,8
7 HALTX=XMIN
GO TO 10
8 IF(HALTX-XMAX)10,10,9
9 HALTX=XMAX
10 IF(ABS(DISTX)-0.1)11,12,12
11 STARTY=THATY
HALTY=THISY
GO TO 13
12 STARTY=THATY+((DISTY*(STARTX-THATX))/DISTX)
HALTY=THISY-((DISTY*(THISX-HALTX))/DISTX)
C
C ********************TEST VERTICAL COORDINATES*********************
13 IF(STARTY-YMIN)14,15,15
14 STARTY=YMIN
LINE=-1
IF(HALTY-YMIN)1,19,19
15 IF(STARTY-YMAX)17,17,16
16 STARTY=YMAX
LINE=-1
IF(HALTY-YMAX)17,17,1
17 IF(HALTY-YMIN)18,19,19
18 HALTY=YMIN
GO TO 21
19 IF(HALTY-YMAX)21,21,20
20 HALTY=YMAX
21 IF(ABS(DISTY)-0.1)23,22,22
22 STARTX=THATX+((DISTX*(STARTY-THATY))/DISTY)
HALTX=THISX-((DISTX*(THISY-HALTY))/DISTY)
C
C **************************PROVIDE SPACE***************************
23 IF(LINE)27,24,28
24 DISTX=HALTX-STARTX
DISTY=HALTY-STARTY
DIST=SQRT((DISTX*DISTX)+(DISTY*DISTY))
IF(DIST-0.01)1,1,25
25 REMAIN=REMAIN-DIST
IF(REMAIN)26,26,1
26 STARTX=HALTX+(REMAIN*DISTX/DIST)
STARTY=HALTY+(REMAIN*DISTY/DIST)
27 NEWX=STARTX
NEWY=STARTY
REMAIN=DASH
LINE=1
CALL PENUP (LASTX,LASTY,NEWX,NEWY)
C
C ****************************PLOT DASH*****************************
28 DISTX=HALTX-STARTX
DISTY=HALTY-STARTY
DIST=SQRT((DISTX*DISTX)+(DISTY*DISTY))
IF(DIST-0.01)1,1,29
29 REMAIN=REMAIN-DIST
IF(REMAIN)30,30,31
30 STARTX=HALTX+(REMAIN*DISTX/DIST)
STARTY=HALTY+(REMAIN*DISTY/DIST)
NEWX=STARTX
NEWY=STARTY
REMAIN=SPACE
LINE=0
CALL PENDWN(LASTX,LASTY,NEWX,NEWY)
GO TO 24
31 NEWX=HALTX
NEWY=HALTY
CALL PENDWN(LASTX,LASTY,NEWX,NEWY)
GO TO 1
32 RETURN
END