[Fortran] 纯文本查看 复制代码
PROGRAM PROGRESS
!
USE WINTERACTER
USE RESID
!
IMPLICIT NONE
!
! Number of iterations parameter
TYPE(WIN_MESSAGE) :: MESSAGE
LOGICAL :: QUIT=.FALSE.,login=.false.
INTEGER ::ITYPE
CHARACTER(len=10) ::USERNAME,PASSWORD
REAL :: NUM1,NUM2,RES_NUM
! Initialise Winteracter 初始化窗口
!
CALL WInitialise()
!
! The root window is not needed for this demonstration, so hide it.
!
CALL WindowOpen(HideWindow)
! !登录窗口界面
!
CALL WDialogLoad(IDD_DIALOG001)
CALL WDialogShow(itype=Modeless)
DO WHILE(.NOT.LOGIN)
CALL WMessage(ITYPE,MESSAGE)
SELECT CASE (ITYPE)
CASE (PushButton)
SELECT CASE (MESSAGE%VALUE1)
CASE (IDOK)
CALL WDialogGetString(IDF_STRING1,USERNAME)
CALL WDialogGetString(IDF_STRING2,PASSWORD)
IF((PASSWORD=="admin").and.(USERNAME=="admin")) then !判断密码是否正确,也可以将密码放入数组中,
!这样可以实现多用户登录
login=.TRUE.
ELSE
CALL WMessageBox(OKONLY,ExclamationIcon,CommonOK,'Username or Password is not correct,please try again','Caution') !密码不正确的提示
login=.false. !密码不对返回再次输入
end if
CASE (IDF_CANCLE) !不登录软件,直接退出
stop
END SELECT
END SELECT
END DO
CALL WDialogUnload() !这个步骤很重要即登录窗口登录后,验证密码无误将登录窗口关闭
!主程序窗口
CALL WDialogLoad(IDD_DIALOG002)
CALL WDialogShow(itype=Modeless)
!****************************************************
!****************************************************
100 DO WHILE(.NOT.QUIT)
CALL WMessage(ITYPE,MESSAGE)
SELECT CASE (ITYPE)
CASE (PushButton)
SELECT CASE (MESSAGE%VALUE1)
CASE (IDRUN)
CALL WDialogGetReal(IDF_real1,num1) !****
CALL WDialogGetReal(IDF_real2,num2) !这两个密令用来获取输入的数据
RES_NUM=num1+num2 !将输入的数据相加
CALL WDialogPutReal(IDF_real3,RES_NUM) !将结果输出到结果框中
QUIT=.FALSE.
CASE (IDCANCEL)
QUIT=.TRUE.
END SELECT
END SELECT
END DO
CALL WindowClose()
STOP
END PROGRAM PROGRESS