home *** CD-ROM | disk | FTP | other *** search
/ Monster Media 1994 #1 / monster.zip / monster / PROG_BAS / PBC23C.ZIP / DWINMAN.BAS < prev    next >
BASIC Source File  |  1994-03-13  |  4KB  |  131 lines

  1. '   +----------------------------------------------------------------------+
  2. '   |                                                                      |
  3. '   |        PBClone  Copyright (c) 1990-1994  Thomas G. Hanlin III        |
  4. '   |                                                                      |
  5. '   +----------------------------------------------------------------------+
  6.  
  7.    DECLARE SUB CalcAttr (BYVAL Foreground%, BYVAL Background%, VAttr%)
  8.    DECLARE SUB DelayV (BYVAL MilliSeconds%)
  9.    DECLARE SUB DReColorArea (BYVAL DSeg%, BYVAL DOfs%, BYVAL TopRow%, BYVAL LeftCol%, BYVAL BottomRow%, BYVAL RightCol%, BYVAL VAttr%)
  10.    DECLARE SUB DXQPrint (BYVAL DSeg%, BYVAL DOfs%, St$, BYVAL Row%, BYVAL Column%, BYVAL VAttr%)
  11.  
  12. SUB DWindowManager (DSeg%, DOfs%, TopRow%, LeftCol%, BottomRow%, RightCol%, Frame%, Fore%, Back%, Grow%, Shade%, TitleFore%, Title$)
  13.  
  14.    CalcAttr Fore%, Back%, VAttr%
  15.  
  16.    IF Grow% THEN
  17.       XD% = RightCol% - LeftCol% + 1
  18.       YD% = BottomRow% - TopRow% + 1
  19.       Y1% = TopRow% + YD% \ 2
  20.       X1% = LeftCol% + XD% \ 2
  21.       Y2% = BottomRow% - YD% \ 2
  22.       X2% = RightCol% - XD% \ 2
  23.       IF YD% > XD% THEN
  24.          XDelta% = 1
  25.          YDelta% = (YD% + XD% \ 2) \ XD%
  26.          IF YDelta% < 1 THEN YDelta% = 1
  27.       ELSE
  28.          YDelta% = 1
  29.          XDelta% = (XD% + YD% \ 2) \ YD%
  30.          IF XDelta% < 1 THEN XDelta% = 1
  31.       END IF
  32.       DO
  33.          Y1% = Y1% - YDelta%
  34.          IF Y1% < TopRow% THEN Y1% = TopRow%
  35.          X1% = X1% - XDelta%
  36.          IF X1% < LeftCol% THEN X1% = LeftCol%
  37.          Y2% = Y2% + YDelta%
  38.          IF Y2% > BottomRow% THEN Y2% = BottomRow%
  39.          X2% = X2% + XDelta%
  40.          IF X2% > RightCol% THEN X2% = RightCol%
  41.          GOSUB MakeWindow
  42.          IF Grow% > 0 THEN DelayV Grow%
  43.       LOOP UNTIL Y1% = TopRow% AND X1% = LeftCol% AND Y2% = BottomRow% AND X2% = RightCol%
  44.    ELSE
  45.       Y1% = TopRow%
  46.       X1% = LeftCol%
  47.       Y2% = BottomRow%
  48.       X2% = RightCol%
  49.       GOSUB MakeWindow
  50.    END IF
  51.  
  52.    EXIT SUB
  53.  
  54.  
  55.  
  56. MakeWindow:
  57.    tmp% = X2% - X1% + 1
  58.    IF Frame% AND 1 THEN
  59.       TopSt$ = STRING$(tmp%, "─")
  60.    ELSE
  61.       TopSt$ = STRING$(tmp%, "═")
  62.    END IF
  63.    MidSt$ = SPACE$(tmp%)
  64.    BotSt$ = TopSt$
  65.    SELECT CASE Frame%
  66.       CASE 1
  67.          TopSt$ = "┌" + TopSt$ + "┐"
  68.          MidSt$ = "│" + MidSt$ + "│"
  69.          BotSt$ = "└" + BotSt$ + "┘"
  70.       CASE 2
  71.          TopSt$ = "╔" + TopSt$ + "╗"
  72.          MidSt$ = "║" + MidSt$ + "║"
  73.          BotSt$ = "╚" + BotSt$ + "╝"
  74.       CASE 3
  75.          TopSt$ = "╓" + TopSt$ + "╖"
  76.          MidSt$ = "║" + MidSt$ + "║"
  77.          BotSt$ = "╙" + BotSt$ + "╜"
  78.       CASE 4
  79.          TopSt$ = "╒" + TopSt$ + "╕"
  80.          MidSt$ = "│" + MidSt$ + "│"
  81.          BotSt$ = "╘" + BotSt$ + "╛"
  82.       CASE 5
  83.          TopSt$ = STRING$(tmp% + 2, "▄")
  84.          MidSt$ = "▌" + MidSt$ + "▐"
  85.          BotSt$ = STRING$(tmp% + 2, "▀")
  86.       CASE ELSE
  87.          TopSt$ = SPACE$(tmp% + 2)
  88.          MidSt$ = TopSt$
  89.          BotSt$ = TopSt$
  90.    END SELECT
  91.  
  92.    Row% = Y1% - 1
  93.    Col% = X1% - 1
  94.    IF LEN(Title$) > 0 AND LEN(TopSt$) >= 4 THEN
  95.       St$ = LEFT$(Title$, LEN(TopSt$) - 4)
  96.       MID$(TopSt$, 2) = "[" + St$ + "]"
  97.       DXQPrint DSeg%, DOfs%, TopSt$, Row%, Col%, VAttr%
  98.       CalcAttr TitleFore%, Back%, TAttr%
  99.       DXQPrint DSeg%, DOfs%, St$, Row%, Col% + 2, TAttr%
  100.    ELSE
  101.       DXQPrint DSeg%, DOfs%, TopSt$, Row%, Col%, VAttr%
  102.    END IF
  103.    FOR Row% = Y1% TO Y2%
  104.       DXQPrint DSeg%, DOfs%, MidSt$, Row%, Col%, VAttr%
  105.    NEXT
  106.    DXQPrint DSeg%, DOfs%, BotSt$, Y2% + 1, Col%, VAttr%
  107.  
  108.    Col% = X1% - 3
  109.    IF Shade% < 0 THEN
  110.       IF Shade% = -1 THEN
  111.          SAttr% = 0
  112.       ELSE
  113.          SAttr% = 8
  114.       END IF
  115.       IF Shade% < -2 THEN
  116.          DReColorArea DSeg%, DOfs%, Y1%, X2% + 2, Y2% + 1, X2% + 3, SAttr%
  117.          DReColorArea DSeg%, DOfs%, Y2% + 2, X1% + 1, Y2% + 2, X2% + 3, SAttr%
  118.       ELSE
  119.          DReColorArea DSeg%, DOfs%, Y1%, Col%, Y2% + 1, X1% - 2, SAttr%
  120.          DReColorArea DSeg%, DOfs%, Y2% + 2, Col%, Y2% + 2, X2% - 1, SAttr%
  121.       END IF
  122.    ELSEIF Shade% THEN
  123.       FOR Row% = Y1% TO Y2% + 1
  124.          DXQPrint DSeg%, DOfs%, "░░", Row%, Col%, Shade%
  125.       NEXT
  126.       DXQPrint DSeg%, DOfs%, STRING$(X2% - X1% + 3, "░"), Y2% + 2, Col%, Shade%
  127.    END IF
  128.    RETURN
  129.  
  130. END SUB
  131.