Cloned SEACAS for EXODUS library with extra build files for internal package management.
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

613 lines
20 KiB

2 years ago
C Copyright(C) 1999-2020 National Technology & Engineering Solutions
C of Sandia, LLC (NTESS). Under the terms of Contract DE-NA0003525 with
C NTESS, the U.S. Government retains certain rights in this software.
C
C See packages/seacas/LICENSE for details
C=======================================================================
SUBROUTINE MSLAB (A, NEWSET, NVWTIM, IPTIMS, TIMES,
& NAMECO, NAMES, IELBST,
& ISSNPS, IDNPS, ISSESS, IDESS, ISCNPS, ISCESS,
& DLEGND, LIDSP, BLKCOL, *)
C=======================================================================
C --*** MSLAB *** (MESH) Label plot
C -- Modified by John Glick - 11/9/88
C -- Written by Amy Gilkey - revised 05/26/88
C -- D. P. Flanagan, 07/27/82
C --
C --MSLAB erases the display surface then labels the graphic frame
C --with the following graphics structures:
C --
C -- BANNER - the title, creator, modifier, and user information.
C -- Constant for entire run. If QA only.
C -- LABEL - includes the variable name, contour labels, magnification
C -- factor, plot time, and axis orientation indicator. Except
C -- for plot time and the min/max nodal values, this structure
C -- is constant for a particular plot set.
C -- CAPTION - the plot caption.
C -- AXES - tick-marked with numeric labels and text labels.
C --
C --All view windows are outlined.
C --
C --The vertical-to-horizontal aspect ratio is assumed to be 0.75.
C --Label locations are set for a horizontal layout.
C --
C --The lengths and minimum/maximums of the axes must be set before
C --this routine is called.
C --
C --Parameters:
C -- A - IN - the dynamic memory base array
C -- NEWSET - IN - true iff starting a new plot set
C -- NVWTIM - IN - the number of times on this plot; 0 for no time
C -- IPTIMS - IN - the plot time indices (starting with current plot)
C -- TIMES - IN - the database times
C -- NAMECO - IN - the coordinate names
C -- NAMES - IN - the variable names
C -- IELBST - IN - the element block status:
C -- -1 = OFF, 0 = ON, but not selected, 1 = selected
C -- ISSNPS - IN - the indices of the selected node sets
C -- IDNPS - IN - the node set IDs
C -- ISSESS - IN - the indices of the selected side sets
C -- IDESS - IN - the side set IDs
C -- ISCNPS - IN/OUT - size = NUMNPS, set iff NEWSET
C -- ISCESS - IN/OUT - size = NUMESS, set iff NEWSET
C -- DLEGND - OUT - the limits of the special legend area
C -- LIDSP(0:*) - IN/OUT - the indices of the selected variables
C -- whose values will be displayed on the plot legend.
C -- ABS(LIDSP(0)) = the number of variables in the list.
C -- SIGN(LIDSP(0)) specifies whether the variables in the
C -- list should have their values displayed on
C -- the plot legend. If >0, they should;
C -- If <=0, they should not.
C -- LIDSP(i) identifies the ith variable in the list.
C -- If LIDSP(i) > 0, LIDSP(i) is the id of a history variable.
C -- If LIDSP(i) < 0, -LIDSP(i) is the id of a global variable.
C -- If LIDSP(i) = 0, TIME is to be displayed on the plot legend.
C -- BLKCOL - IN/OUT - the user selected colors of the element blocks.
C -- BLKCOL(0) = 1 if the user defined material
C -- colors should be used in mesh plots.
C -- = -1 if program selected colors should
C -- be used.
C -- BLKCOL(i) = the user selected color of element
C -- block i:
C -- -2 - no color selected by user.
C -- -1 - black
C -- 0 - white
C -- 1 - red
C -- 2 - green
C -- 3 - yellow
C -- 4 - blue
C -- 5 - cyan
C -- 6 - magenta
C -- * - return statement if the cancel function is active
C --
C --Common Variables:
C -- Uses TITLE, CREATE, MODIFY, DRAW of /DBTITL/
C -- Uses NDIM, NELBLK of /DBNUMS/
C -- Uses IS3DIM of /D3NUMS/
C -- Uses DOQA, DOLEG, DOAXIS, CAPTN of /LEGOPT/
C -- Uses DFAC of /DEFORM/
C -- Uses MSHDEF, NALVAR, DEADNP of /MSHOPT/
C -- Uses XISSYM, YISSYM of /VIEWS/
C -- Uses TICMSH of /MSHLIM/
C -- Uses ROTMAT of /ROTOPT/
C -- Uses CHLSIZ, DBORD0, DVIEW0, DVIEW, WVIEW of /LAYOUT/
PARAMETER (KLFT=1, KRGT=2, KBOT=3, KTOP=4, KNEA=5, KFAR=6)
PARAMETER (KXORIG=1, KYORIG=2, KXLENG=3, KYLENG=4)
PARAMETER (KXNUMS=22, KXLABS=23, KYNUMS=47, KYLABS=48)
PARAMETER (KSCALE=11)
PARAMETER (KTICSZ=33)
include 'params.blk'
include 'dbtitl.blk'
include 'dbnums.blk'
include 'dbnumgq.blk'
include 'd3nums.blk'
include 'legopt.blk'
include 'deform.blk'
include 'mshopt.blk'
include 'views.blk'
include 'mshlim.blk'
include 'rotopt.blk'
include 'layout.blk'
include 'layoud.blk'
common /debugc/ cdebug
common /debugn/ idebug
character*8 cdebug
DIMENSION A(*)
LOGICAL NEWSET
INTEGER IPTIMS(*)
REAL TIMES(*)
CHARACTER*(*) NAMECO(*)
CHARACTER*(*) NAMES(*)
INTEGER IELBST(NELBLK)
INTEGER ISSNPS(NUMNPS,4)
INTEGER ISSESS(NUMESS,4)
INTEGER IDNPS(*)
INTEGER IDESS(*)
INTEGER ISCNPS(*)
INTEGER ISCESS(*)
INTEGER LIDSP(0:*)
INTEGER BLKCOL(0:NELBLK)
REAL DLEGND(KTOP)
LOGICAL PLTGTG, PLTSTG, PLTSTG1, MPVIEW, MPORT2, LDUM
LOGICAL GRABRT
INTEGER NUMMOD, NDEFVW, IXVW
LOGICAL SOFTCH
LOGICAL XISCOP, YISCOP
LOGICAL RGTVW, TOPVW
CHARACTER*80 STRING
CHARACTER*20 RSTR(3)
REAL BUF(11)
REAL X(4)
REAL XPT(0:3), YPT(0:3), ZPT(0:3)
REAL WAVIEW(KTOP), DAVIEW(KTOP)
REAL ZERO3(3)
SAVE ZERO3
SAVE NNPS, NESS
SAVE DTOP, DBOT, DYMAGN, DYELB, DYALIV, DYSETS,
& DYTIME, EYTIME, DYXYZ, EYXYZ
CHARACTER*(MXSTLN+1) DISPVL
REAL VARVAL
INTEGER IDVAR
INTEGER NUMDSP
LOGICAL FIRSTH, FIRSTG
DATA ZERO3 / 0.0, 0.0, 0.0 /
RGTVW(I) = (I .EQ. 2) .OR. (I .EQ. 4)
TOPVW(I) = (I .EQ. 1) .OR. (I .EQ. 2)
C *** Standard plot labeling ***
CALL QALAB (DBORD0, DVIEW0, CHLSIZ,
& DOQA(1), DOAXIS(1), (.NOT. IS3DIM),
& CAPTN(1,1), TITLE, CREATE, MODIFY, DRAW, DLEGND,
& BLKCOL, *220)
C *** Plot legend ***
IF (.NOT. DOLEG(1)) GOTO 200
C --Set up labeling
IF (NEWSET) THEN
DTOP = DLEGND(KTOP) - CHLSIZ
IF (DOQA(1)) THEN
DTOP = DTOP - 2*CHLSIZ
END IF
IF (NVWTIM .GT. 0) THEN
DYMAGN = DTOP
DTOP = DYMAGN - 2*CHLSIZ
ELSE
DYMAGN = 0.0
END IF
DYELB = DTOP
DTOP = DYELB - 3*CHLSIZ
IF (NALVAR .GT. 0) THEN
DYALIV = DTOP
IF (DEADNP) THEN
DTOP = DYALIV - 3.5*CHLSIZ
ELSE
DTOP = DYALIV - 2*CHLSIZ
END IF
ELSE
DYALIV = 0.0
END IF
C --Get the number of lines and the identifiers for node sets
C --and side sets
NNPS = 0
NESS = 0
DO 120 IVW = 1, NDEFVW (.FALSE.)
IVIEW = IXVW (.FALSE., IVW)
DO 100 IX = 1, NNPSET(IVIEW)
I = ISSNPS(IX,IVIEW)
IF (LOCINT (I, NNPS, ISCNPS) .LE. 0) THEN
NNPS = NNPS + 1
ISCNPS(NNPS) = I
END IF
100 CONTINUE
DO 110 IX = 1, NESSET(IVIEW)
I = ISSESS(IX,IVIEW)
IF (LOCINT (I, NESS, ISCESS) .LE. 0) THEN
NESS = NESS + 1
ISCESS(NESS) = I
END IF
110 CONTINUE
120 CONTINUE
IF ((NNPS .GT. 0) .OR. (NESS .GT. 0)) THEN
DYSETS = DTOP
NL = MIN (NNPS, 1) + NNPS + MIN (NNPS, 1)
& + MIN (NESS, 1) + NESS + MIN (NESS, 1) - 1
DTOP = DTOP - NL * CHLSIZ
END IF
DBOT = DLEGND(KBOT)
IF (IS3DIM) THEN
EYXYZ = DBOT + 0.5*CHLSIZ
DYXYZ = EYXYZ + .1 - 0.5*CHLSIZ
DBOT = DYXYZ + 2.5*CHLSIZ
ELSE
EYXYZ = 0.0
DYXYZ = 0.0
END IF
IF (NVWTIM .GT. 0) THEN
EYTIME = DBOT
DYTIME = EYTIME + (NVWTIM-1) * CHLSIZ
DBOT = DYTIME + CHLSIZ
ELSE
EYTIME = 0.0
DYTIME = 0.0
END IF
END IF
C --Set the top and bottom of the remaining legend area
DLEGND(KTOP) = DTOP
DLEGND(KBOT) = DBOT
C --Get software character flag for current device
CALL GRGPARD ('SOFTCHAR', 0, SOFTCH, STRING)
C --Magnification factor
IF (NVWTIM .GT. 0) THEN
IF (GRABRT ()) RETURN 1
IF ((NUMMOD (MSHDEF, ' ', 'DEFORM', ' ') .GE. 1)
& .AND. (DFAC .NE. 0.0)) THEN
CALL NUMSTR (1, 4, DFAC, RSTR(1), LSTR)
CALL GRTEXT (DLEGND(KLFT), DYMAGN,
& 'MAGNIFIED BY ' // RSTR(1))
ELSE
CALL GRTEXT (DLEGND(KLFT), DYMAGN,
& 'NO MAGNIFICATION')
END IF
END IF
C --Active element blocks
IF (GRABRT ()) RETURN 1
CALL CNTELB (IELBST, NELBLK, NUMON, NUMSEL)
CALL GRTEXT (DLEGND(KLFT), DYELB, 'ELEMENT BLOCKS ACTIVE:')
WRITE (STRING, 10000, IOSTAT=IDUM) NUMSEL, NELBLK
10000 FORMAT (I5, ' OF ', I5)
CALL SQZSTR (STRING, LSTR)
CALL GRTEXT (DLEGND(KLFT), DYELB-CHLSIZ, ' ' // STRING(:LSTR))
C --Birth/death variable indicator
IF (NALVAR .GT. 0) THEN
IF (GRABRT ()) RETURN 1
CALL GRTEXT (DLEGND(KLFT), DYALIV,
& 'BIRTH/DEATH: ' // NAMES(NALVAR))
IF (DEADNP) THEN
IF (GRABRT ()) RETURN 1
DY = DYALIV - 1.5*CHLSIZ
#if NeedsDoubleEscape
CALL PLTXTS (DLEGND(KLFT), DY+.4*CHLSIZ, '\\CDO')
#else
CALL PLTXTS (DLEGND(KLFT), DY+.4*CHLSIZ, '\CDO')
#endif
CALL PLTXSE (DX, RDUM)
CALL GRTEXT (DX, DY, ' = DEAD NODE')
END IF
END IF
C --Label the node sets
DY = DYSETS
IF (NNPS .GT. 0) THEN
IF (DY .LT. DBOT) GOTO 150
IF (GRABRT ()) RETURN 1
CALL GRTEXT (DLEGND(KLFT), DY, 'NODE SETS:')
DY = DY - CHLSIZ
DO 130 IX = 1, NNPS
IF (DY .LT. DBOT) GOTO 150
INPS = ISCNPS(IX)
IF (GRABRT ()) RETURN 1
CALL GRCOLR (INPS)
#if NeedsDoubleEscape
CALL PLTXTS (DLEGND(KLFT), DY, '\\CI')
#else
CALL PLTXTS (DLEGND(KLFT), DY, '\CI')
#endif
CALL PLTXSE (DX, RDUM)
CALL INTSTR (1, 0, IDNPS(INPS), STRING, LSTR)
CALL GRTEXT (DX, DY, ' = ID ' // STRING(:LSTR))
DY = DY - CHLSIZ
130 CONTINUE
DY = DY - CHLSIZ
END IF
CALL UGRCOL (0, BLKCOL)
C --Label the side sets
IF (NESS .GT. 0) THEN
IF (DY .LT. DBOT) GOTO 150
IF (GRABRT ()) RETURN 1
CALL GRTEXT (DLEGND(KLFT), DY, 'SIDE SETS:')
DY = DY - CHLSIZ
DO 140 IX = 1, NESS
IF (DY .LT. DBOT) GOTO 150
IESS = ISCESS(IX)
IF (GRABRT ()) RETURN 1
CALL GRCOLR (IESS)
BOXSIZ = 0.8 * CHLSIZ
DX = DLEGND(KLFT) + BOXSIZ
CALL GRBOX (' ', DLEGND(KLFT), DX, DY, DY+BOXSIZ)
CALL INTSTR (1, 0, IDESS(IESS), STRING, LSTR)
CALL GRTEXT (DX, DY, ' = ID ' // STRING(:LSTR))
DY = DY - CHLSIZ
140 CONTINUE
DY = DY - CHLSIZ
END IF
CALL UGRCOL (0, BLKCOL)
150 CONTINUE
CALL UGRCOL (0, BLKCOL)
C --Plot time
IF ((NVWTIM .GT. 0) .AND. (LIDSP(0) .GT. 0)) THEN
IF (GRABRT ()) RETURN 1
DY = EYTIME
C Determine the number of variables whose value will be
C displayed in the plot legend.
NUMDSP = LIDSP(0)
IF (NVWTIM .EQ. 4) THEN
NUMDSP = MIN (NUMDSP, 1)
ELSE IF (NVWTIM .EQ. 3) THEN
NUMDSP = MIN (NUMDSP, 1)
ELSE IF (NVWTIM .EQ. 1) THEN
NUMDSP = MIN (NUMDSP, 4)
ELSE
NUMDSP = MIN (NUMDSP, 2)
ENDIF
DO 170 I = NVWTIM, 1, -1
FIRSTH = .TRUE.
FIRSTG = .TRUE.
DO 160 J = NUMDSP, 1, -1
IF (LIDSP(J) .EQ. 0) THEN
DISPVL = 'TIME'
VARVAL = TIMES(IPTIMS(I))
ELSE IF (LIDSP(J) .GT. 0)THEN
IF (FIRSTH) THEN
CALL DBVIX_BL ('H', 1, IXHV)
CALL MDRSRV ('SCRH', KVARH, NVARHI)
CALL MDSTAT (NERR, MEM)
IF (NERR .GT. 0)GOTO 180
CALL GETVAR (A, IXHV, 0, IPTIMS(I), NVARHI,
& A(KVARH))
FIRSTH = .FALSE.
ENDIF
CALL DBVIX_BL ('H', LIDSP(J), IDVAR)
DISPVL = NAMES(IDVAR)
VARVAL = A(KVARH+LIDSP(J)-1)
ELSE
IF (FIRSTG) THEN
CALL DBVIX_BL ('G', 1, IXGV)
CALL MDRSRV ('SCRG', KVARG, NVARGL)
CALL MDSTAT (NERR, MEM)
IF (NERR .GT. 0)GOTO 180
CALL GETVAR (A, IXGV, 0, IPTIMS(I), NVARGL,
& A(KVARG))
FIRSTG = .FALSE.
ENDIF
CALL DBVIX_BL ('G', -LIDSP(J), IDVAR)
DISPVL = NAMES(IDVAR)
VARVAL = A(KVARG-LIDSP(J)-1)
ENDIF
CALL NUMSTR (1, 4, VARVAL, RSTR(1), LSTR)
CALL GRTEXT (DLEGND(KLFT), DY,
& DISPVL(:LENSTR(DISPVL)) // ' ' // RSTR(1)(:LSTR))
DY = DY + CHLSIZ
160 CONTINUE
IF (.NOT. FIRSTH) CALL MDDEL ('SCRH')
IF (.NOT. FIRSTG) CALL MDDEL ('SCRG')
170 CONTINUE
ENDIF
C --Orientation indicator
180 CONTINUE
IF (IS3DIM) THEN
CALL BL_ROTATE (1, 1, ROTMAT, ZERO3,
& 0.0, 0.0, 0.0, XPT(0), YPT(0), ZPT(0))
CALL BL_ROTATE (1, 1, ROTMAT, ZERO3,
& 1.0, 0.0, 0.0, XPT(1), YPT(1), ZPT(1))
CALL BL_ROTATE (1, 1, ROTMAT, ZERO3,
& 0.0, 1.0, 0.0, XPT(2), YPT(2), ZPT(2))
CALL BL_ROTATE (1, 1, ROTMAT, ZERO3,
& 0.0, 0.0, 1.0, XPT(3), YPT(3), ZPT(3))
X(KLFT) = MIN (XPT(0), XPT(1), XPT(2), XPT(3))
X(KRGT) = MAX (XPT(0), XPT(1), XPT(2), XPT(3))
X(KBOT) = MIN (YPT(0), YPT(1), YPT(2), YPT(3))
X(KTOP) = MAX (YPT(0), YPT(1), YPT(2), YPT(3))
CALL SQRLIM (X, X)
DX = DLEGND(KLFT) + 2*CHLSIZ
EX = DX + (DYXYZ - EYXYZ)
LDUM = MPVIEW (DX, EX, EYXYZ, DYXYZ)
LDUM = MPORT2 (X(KLFT), X(KRGT), X(KBOT), X(KTOP))
CALL MP2PT (1, XPT(0), YPT(0), XPT(0), YPT(0), IDUM)
DO 190 I = 1, 3
CALL MP2PT (1, XPT(I), YPT(I), XPT(I), YPT(I), IDUM)
CALL GRTEXC (XPT(I), YPT(I)-0.5*CHLSIZ, NAMECO(I))
X(1) = 0
X(2) = 0
X(3) = 0
X(I) = .9
CALL BL_ROTATE (1, 1, ROTMAT, ZERO3,
& X(1), X(2), X(3), XPT(I), YPT(I), ZPT(I))
CALL MP2PT (1, XPT(I), YPT(I), XPT(I), YPT(I), IDUM)
CALL PLTARR (XPT(0), YPT(0), XPT(I), YPT(I), 0.5, .01)
190 CONTINUE
END IF
200 CONTINUE
C *** Axes ***
C --Reset coordinate system
CALL MPINIT
XISCOP = (.NOT. XISSYM) .AND. (MSHDEF(1) .NE. 'NONE')
YISCOP = (.NOT. YISSYM) .AND. (MSHDEF(4) .NE. 'NONE')
IF (.NOT. DOAXIS(1)) THEN
LDUM = PLTSTG1 (KXNUMS, 0.0)
LDUM = PLTSTG1 (KYNUMS, 0.0)
LDUM = PLTSTG1 (KTICSZ, 0.0)
END IF
C --Compute tick-interval parameters
IF (XISSYM) THEN
WAVIEW(KLFT) = WVIEW(KLFT,2) - (WVIEW(KRGT,2) - WVIEW(KLFT,2))
DAVIEW(KLFT) = DVIEW(KLFT,2) - (DVIEW(KRGT,2) - DVIEW(KLFT,2))
ELSE
WAVIEW(KLFT) = WVIEW(KLFT,2)
DAVIEW(KLFT) = DVIEW(KLFT,2)
END IF
WAVIEW(KRGT) = WVIEW(KRGT,2)
DAVIEW(KRGT) = DVIEW(KRGT,2)
IF (YISSYM) THEN
WAVIEW(KBOT) = WVIEW(KBOT,2) - (WVIEW(KTOP,2) - WVIEW(KBOT,2))
DAVIEW(KBOT) = DVIEW(KBOT,2) - (DVIEW(KTOP,2) - DVIEW(KBOT,2))
ELSE
WAVIEW(KBOT) = WVIEW(KBOT,2)
DAVIEW(KBOT) = DVIEW(KBOT,2)
END IF
WAVIEW(KTOP) = WVIEW(KTOP,2)
DAVIEW(KTOP) = DVIEW(KTOP,2)
WXATIC = TICMSH
WYATIC = TICMSH
CALL GRAPAR (.TRUE., WAVIEW, DAVIEW,
& WXALAB, WYALAB, WXAEND, WYAEND, WXATIC, WYATIC)
WXAMIN = WAVIEW(KLFT)
WXAMAX = WAVIEW(KRGT)
WYAMIN = WAVIEW(KBOT)
WYAMAX = WAVIEW(KTOP)
C --Adjust for non-symmetric views where both min and max will be labeled,
C --causing overlap; move first label in 1/2 tick
IF (XISCOP) THEN
IF (MAX (WXALAB - WXAMIN, WXAMAX - WXAEND) .LE. (0.2 * WXATIC))
& WXALAB = WXALAB + 0.5*WXATIC
END IF
IF (YISCOP) THEN
IF (MAX (WYALAB - WYAMIN, WYAMAX - WYAEND) .LE. (0.2 * WYATIC))
& WYALAB = WYALAB + 0.5*WYATIC
END IF
C --Set up axis length
DXALEN = DAVIEW(KRGT) - DAVIEW(KLFT)
DYALEN = DAVIEW(KTOP) - DAVIEW(KBOT)
LDUM = PLTSTG1 (KXLENG, DXALEN)
LDUM = PLTSTG1 (KYLENG, DYALEN)
C --Set up axis minimum, maximum, and tick intervals
BUF(1) = 4
BUF(2) = WXAMIN
BUF(3) = WXALAB
BUF(4) = WXAMAX
BUF(5) = WXATIC
BUF(6) = 0.0
BUF(7) = WYAMIN
BUF(8) = WYALAB
BUF(9) = WYAMAX
BUF(10)= WYATIC
BUF(11)= 0.0
LDUM = PLTSTG (KSCALE, BUF)
LDUM = PLTGTG (KXNUMS, SZNUM)
LDUM = PLTGTG (KXLABS, SZLAB)
DO 210 IVW = 1, NDEFVW (.TRUE.)
IVIEW = IXVW (.TRUE., IVW)
IF ((IVIEW .EQ. 2)
& .OR. (XISCOP .AND. YISCOP)
& .OR. (XISCOP .AND. TOPVW (IVIEW))
& .OR. (YISCOP .AND. RGTVW (IVIEW))) THEN
IF (GRABRT ()) RETURN 1
C --Set up axes labeling
IF (YISCOP .AND. TOPVW(IVIEW)) THEN
LDUM = PLTSTG1 (KXNUMS, 0.0)
LDUM = PLTSTG1 (KXLABS, 0.0)
ELSE
IF (DOAXIS(1)) LDUM = PLTSTG1 (KXNUMS, SZNUM)
LDUM = PLTSTG1 (KXLABS, SZLAB)
END IF
IF (XISCOP .AND. RGTVW(IVIEW)) THEN
LDUM = PLTSTG1 (KYNUMS, 0.0)
LDUM = PLTSTG1 (KYLABS, 0.0)
ELSE
IF (DOAXIS(1)) LDUM = PLTSTG1 (KYNUMS, SZNUM)
LDUM = PLTSTG1 (KYLABS, SZLAB)
END IF
C --Set the axis start
IF (XISSYM .OR. (.NOT. RGTVW(IVIEW))) THEN
DXASTA = DVIEW(KLFT,1)
ELSE
DXASTA = DVIEW(KLFT,2)
END IF
IF (YISSYM .OR. (.NOT. TOPVW(IVIEW))) THEN
DYASTA = DVIEW(KBOT,4)
ELSE
DYASTA = DVIEW(KBOT,2)
END IF
LDUM = PLTSTG1 (KXORIG, DXASTA)
LDUM = PLTSTG1 (KYORIG, DYASTA)
C --Draw the axes
if (dobox) then
IF (.NOT. IS3DIM) THEN
CALL PLTGPH (0., 0., 0, NAMECO(1), ' ', NAMECO(2), ' ')
ELSE
CALL PLTGPH (0., 0., 0, ' ', ' ', ' ', ' ')
END IF
END IF
end if
210 CONTINUE
C --Flush buffer, so label is complete at this point
CALL PLTFLU
RETURN
220 CONTINUE
RETURN 1
END