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.
 
 
 
 
 
 

53 lines
1.6 KiB

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=======================================================================
LOGICAL FUNCTION MPPERS(FOVY,ASPECT,NEAR,FAR)
CHARACTER*6 SUBNAM
PARAMETER (SUBNAM='MPPERS')
PARAMETER (DPR=57.2958)
REAL NEAR
COMMON /MAP/MODEL(4,4),VIEW(4,4),PROJ(4,4),CPNEAR,CPFAR,VWPORT(4),
* MVP(4,4),VP(4,4),CPLINE(2,2,10),CPPLAN(2,3,10),PEYE(3),
* PLOOK(3),ETWIST,NCPLIN,NCPLAN,TMAT1(4,4),TMAT2(4,4),
* TMAT3(4,4),TVEC1(4),TVEC2(4),TVEC3(4),TVEC4(4),TARR1(32),
* TARR2(32),TARR3(32),TARR4(32),TARR5(32),TARR6(32),
* TARR7(32),TARR8(32)
REAL MODEL,MVP
MPPERS = .FALSE.
IF (NEAR.LT.0.) THEN
CALL PLTFLU
CALL SIORPT(SUBNAM,
* 'You cannot specify the near clipping plane less than 0.'
* ,2)
RETURN
END IF
IF (NEAR.GE.FAR) THEN
CALL PLTFLU
CALL SIORPT(SUBNAM,
*'You cannot specify the near clipping plane >= to the far clipping
* plane',2)
RETURN
END IF
MPPERS = .TRUE.
CALL MXZERO(4,PROJ)
PROJ(2,2) = 1./TAN((FOVY/DPR)/2.)
PROJ(1,1) = PROJ(2,2)/ASPECT
PROJ(3,3) = - (FAR+NEAR)/ (FAR-NEAR)
PROJ(4,3) = - (2.*FAR*NEAR)/ (FAR-NEAR)
PROJ(3,4) = -1.
CPNEAR = NEAR
CPFAR = FAR
CALL MXMULT(4,VIEW,PROJ,VP)
CALL MXMULT(4,MODEL,VP,MVP)
RETURN
END