obsolete.computer

the-maze/original-code-and-data/game.bas

File Type: text/plain

DECLARE FUNCTION LineofSight (x1, y1, x2, y2)
DECLARE SUB Warp (x, y)
DECLARE SUB Drawscreen (ndiamond, cur, ky, tries)
DECLARE SUB Drlin (x1, y1, x2, y2)
DECLARE SUB Drblock (x1, y1, x2, y2)
DECLARE SUB Killdude (x1(), y1(), p, n)
DECLARE FUNCTION Whichone (xx(), yy(), x, y, n)

Randomize Timer
bombtime = 15 'set up speeds of enemies
arrowtime = 30 '(in milliseconds per update)
enemytime = 100
youtime = 15 'and you
x = 40: y = 10
ar = 0: en = 0: bm = 0
bb = 0: ldtim = 0: ld = 0
t$ = "": ensp = 50
Dim room$(30, 100), items(30)
Dim melt%(3000), ky(30), cn(30), dr(30), bx(10), by(10)
Dim ax(10), ay(10), ex(10), ey(10), adr(10), lastc(30)
Screen 9
Open "game.ini" For Input As #1
Input #1, n$
Close #1

start:
GoSub load
For t = 1 To 30
    cn(t) = 0
    dr(t) = 0
    ky(t) = 0
    lastc(t) = 0
Next t
og1 = 0
tries = 4: lastsav = 1
lastx = x: lasty = y
lastn = 0: dead = 0
pc = 24: cur = 1
ky = 0: ndiamond = 0
count = 0
Drawscreen ndiamond, cur, ky, tries
GoSub gtdat

mnlp:
Do
    ox = x: oy = y
    Select Case InKey$
        Case Chr$(0) + "H"
            up = 1: dn = 0: lt = 0: rt = 0
        Case Chr$(0) + "P"
            dn = 1: up = 0: lt = 0: rt = 0
        Case Chr$(0) + "K"
            lt = 1: rt = 0: up = 0: dn = 0
        Case Chr$(0) + "M"
            rt = 1: lt = 0: up = 0: dn = 0
        Case Chr$(27)
            System
        Case "="
            ensp = ensp + 10: If ensp > 200 Then ensp = 200
        Case "-"
            ensp = ensp - 10: If ensp < 10 Then ensp = 10
        Case "l"
            GoTo loadnew
        Case "e"
            Open "editor.ini" For Output As #1
            Print #1, n$
            Close #1
            Chain "editor.exe"
        Case " "
            up = 0: dn = 0: lt = 0: rt = 0
    End Select

    If Timer - lytim >= (youtime / 1000) Then
        If up Then y = y - 1: pc = 24: If y < 1 Then GoTo nwroom
        If dn Then y = y + 1: pc = 25: If y > 20 Then GoTo nwroom
        If lt Then x = x - 1: pc = 27: If x < 1 Then GoTo nwroom
        If rt Then x = x + 1: pc = 26: If x > 80 Then GoTo nwroom
        lytim = Timer
    End If

    Select Case Screen(y, x)
        Case 21
            GoSub savspot
            x = ox: y = oy: up = 0: dn = 0: lt = 0: rt = 0
        Case 233
            GoTo youredead
        Case 176
            Call Warp(x, y)
        Case 4
            GoSub addiamond
        Case 8
            GoSub opndoor
            x = ox: y = oy: up = 0: dn = 0: lt = 0: rt = 0
        Case 5
            GoTo youwin
        Case 244
            GoSub adky
        Case 32 'nothing
        Case 88 'go right over it
        Case pc 'yep
        Case Else
            x = ox: y = oy: up = 0: dn = 0: lt = 0: rt = 0
    End Select
    ld = 0
    If bm Then GoSub Updatebomb
    If ar Then GoSub Updatearrow
    If en Then GoSub Updateenemy
    If ld Then GoSub losediamond
    Locate y, x 'places you on the screen at x, y
    Color 2 '
    Print Chr$(pc) 'pc is the ASCII code, selected above,
    Color 7 'for the facing you have on the screen.
    If oy <> y Or ox <> x Then
        Locate oy, ox
        Print Chr$(32)
    End If
Loop

Updatebomb:
If Timer - lbtim < (bombtime / 1000) Then Return
lbtim = Timer
bb = 1
Do
    ooy = by(bb): oox = bx(bb)
    If x = bx(bb) And Not dead Then
        by(bb) = by(bb) + 1
    Else
        by(bb) = by(bb) - 1
    End If

    If by(bb) < 1 Or by(bb) > 20 Then by(bb) = ooy
    If Screen(by(bb), bx(bb)) = 233 Then 'did we hit a mine?
        Killdude bx(), by(), bb, bm
        Locate ooy, oox: Print " "
    Else
        If Screen(by(bb), bx(bb)) = pc Then ld = -1
        If Screen(by(bb), bx(bb)) = 176 Then Call Warp(bx(bb), by(bb))

        If Screen(by(bb), bx(bb)) = 234 Then
            Killdude ex(), ey(), Whichone(ex(), ey(), bx(bb), by(bb), en), en
        End If
        If Screen(by(bb), bx(bb)) = 16 Or Screen(by(bb), bx(bb)) = 17 Then
            w = Whichone(ax(), ay(), bx(bb), by(bb), ar)
            Killdude ax(), ay(), w, ar
            For t = w To ar
                If t < 10 Then adr(t) = adr(t + 1)
            Next t
        End If

        If Screen(by(bb), bx(bb)) <> 32 And Screen(by(bb), bx(bb)) <> 88 Then by(bb) = ooy

        Locate by(bb), bx(bb)
        Color 13
        Print Chr$(127)
        Color 7
        If ooy <> by(bb) Or oox <> bx(bb) Then
            Locate ooy, oox:
            Print " "
        End If
    End If
    bb = bb + 1
Loop While bb <= bm
Return

Updatearrow:
If Timer - latim < (arrowtime / 1000) Then Return
latim = Timer
bb = 1
Do
    ooy = ay(bb): oox = ax(bb)

    If y = ay(bb) And Not dead Then
        ax(bb) = ax(bb) + adr(bb)
    Else
        ax(bb) = ax(bb) - adr(bb)
    End If

    If ax(bb) < 1 Or ax(bb) > 80 Then ax(bb) = oox

    If Screen(ay(bb), ax(bb)) = 233 Then
        Killdude ax(), ay(), bb, ar
        For t = bb To ar
            If t < 10 Then adr(t) = adr(t + 1)
        Next t
        Locate ooy, oox: Print " "
    Else
        If Screen(ay(bb), ax(bb)) = pc Then ld = -1
        If Screen(ay(bb), ax(bb)) = 176 Then Call Warp(ax(bb), ay(bb))

        If Screen(ay(bb), ax(bb)) = 234 Then
            Killdude ex(), ey(), Whichone(ex(), ey(), ax(bb), ay(bb), en), en
        End If

        If Screen(ay(bb), ax(bb)) = 127 Then
            Killdude bx(), by(), Whichone(bx(), by(), ax(bb), ay(bb), bm), bm
        End If

        If Screen(ay(bb), ax(bb)) <> 88 Then
            If Screen(ay(bb), ax(bb)) <> 32 Then ax(bb) = oox
        End If

        Locate ay(bb), ax(bb)
        Color 2
        Print Chr$(-16 * (adr(bb) = 1) - 17 * (adr(bb) = -1))
        Color 7
        If oox <> ax(bb) Or ooy <> ay(bb) Then Locate ooy, oox: Print " "
    End If
    bb = bb + 1
Loop While bb <= ar
Return

Updateenemy:
If Timer - letim < (enemytime / 1000) Then Return
letim = Timer 'only updates every <enemytime> milliseconds

bb = 1 'enemy number
Do
    oox = ex(bb): ooy = ey(bb) 'sets old position
    seen = LineofSight(x, y, ex(bb), ey(bb)) 'tests line of sight

    If seen And Not dead Then 'they're gonna chase you!

        'this is a hugely nested IF statement!

        If Rnd(1) > .2 Then
            If Abs(ex(bb) - x) >= Abs(ey(bb) - y) Then 'move him towards you
                ex(bb) = ex(bb) + Sgn(x - ex(bb))
            Else
                ey(bb) = ey(bb) + Sgn(y - ey(bb))
            End If
        Else 'vary his step a bit
            If Abs(ex(bb) - x) >= Abs(ey(bb) - y) Then
                ey(bb) = ey(bb) + Int(Cos(Timer Mod 180 * 3.14 * 2 + bb) + .5)
            Else
                ex(bb) = ex(bb) + Int(Cos(Timer Mod 180 * 3.14 * 2 + bb) + .5)
            End If
        End If

    Else 'if you're not in sight

        If Rnd(1) > .5 Then 'walk him around in circles
            ey(bb) = ey(bb) + Int(Sin(Timer Mod 180 * 3.14 * 2 + bb) + .5) * ((bb Mod 2) - .5) * 2
        Else
            ex(bb) = ex(bb) + Int(Cos(Timer Mod 180 * 3.14 * 2 + bb) + .5)
        End If

    End If

    If ey(bb) < 1 Or ey(bb) > 20 Then ey(bb) = ooy 'checks to make sure the
    If ex(bb) < 1 Or ex(bb) > 80 Then ex(bb) = oox 'guy isn't off-screen

    If Screen(ey(bb), ex(bb)) = 233 Then ' if we've bumped into a mine
        Killdude ex(), ey(), bb, en ' blow him up
        Locate ooy, oox: Print " " ' and destroy the corpse
    Else ' otherwise...
        ' check for other stuff

        If Screen(ey(bb), ex(bb)) = 176 Then Warp ex(bb), ey(bb) 'warp tile

        If Screen(ey(bb), ex(bb)) = pc Then ld = -1 'he's taking
        'diamonds

        If Screen(ey(bb), ex(bb)) <> 32 Then 'if he's touching anything
            ex(bb) = oox: ey(bb) = ooy 'then move him back to his
        Else 'old position
            Locate ooy, oox: Print Chr$(32) 'otherwise move him
            Locate ey(bb), ex(bb)
            Color bb + 2 + (5 * (bb > 5)) 'selects colors for each enemy
            'COLOR 9 + seen * 5           'selects color based on line of sight
            Print Chr$(234)
            Color 7
        End If

    End If

    bb = bb + 1
Loop While bb <= en 'update the next guy

Return

nwroom:
If y > 20 Then cur = cur + 5: y = 1
If y < 1 Then cur = cur - 5: y = 20
If x > 80 Then cur = cur + 1: x = 1
If x < 1 Then cur = cur - 1: x = 80
ox = x: oy = y
Call Drawscreen(ndiamond, cur, ky, tries)
GoSub gtdat
GoTo mnlp

losediamond:
If Timer - ldtime < .5 Then Return
ldtime = Timer
ndiamond = ndiamond - 1
If ndiamond < 0 Then ndiamond = 0: GoTo youredead
Locate 22, 2
Color 15
Print "Diamonds: "; ndiamond
Color 7
Play "L64O2BBAG"
Return

addiamond:
cn(cur) = -1
ndiamond = ndiamond + 1
Locate 22, 2
Color 15
Print "Diamonds: "; ndiamond
Color 7
Play "L64O3cfa"
Return

opndoor:
If ky > 0 Then
    ky = ky - 1
    dr(cur) = -1
    Locate 23, 60
    Color 15
    Print "Keys: "; ky
    Color 7
    Play "L64O0cfbO1e"
    For i = 1 To 80
        For j = 1 To 20
            If Screen(j, i) = 8 Then Locate j, i: Print " "
        Next j
    Next i
Else
    Play "l64o0af"
End If
Return

adky:
ky = ky + 1
ky(cur) = -1
Color 15
Locate 23, 60
Print "*Keys: "; ky; "*"
Color 7
Play "l64O3cf"
Return

youredead:
dead = -1
Locate oy, ox
Color 4
Print "X"
Locate 22, 35
Color 12
Print "You're Dead"
Color 7
Play "l64O3cO2dO1eO0e"
t = Timer
Do
    nul$ = InKey$
    If bm Then GoSub Updatebomb
    If ar Then GoSub Updatearrow
    If en Then GoSub Updateenemy
Loop While Timer - t < 2
tries = tries - 1
If tries < 0 Then GoTo gameover
ndiamond = lastn
cur = lastsav
x = lastx
y = lasty
og1 = 0
For t = 1 To 30
    cn(t) = lastc(t)
Next t
dead = 0
GoTo nwroom

savspot:
lastn = ndiamond
lastsav = cur
lastx = x
lasty = y
For t = 1 To 30:
    lastc(t) = cn(t)
Next t
Color 14
Locate 23, 32
Print "*Continue Point*"
Color 7
Play "L64O2cdefg"
Return

gameover:
For t = 1 To 80
    nul$ = InKey$
Next t
Locate 11, 32
Color 4
Print "G A M E  O V E R"
Sleep 2
r = 0
Do
    r = r + 1
    xx = Int(Rnd * 595)
    YX = Int(Rnd * 150)
    Get (xx, YX)-(xx + 45, YX + 45), melt%()
    Put (xx, YX + 1), melt%(), PSet
    If InKey$ <> "" Then Exit Do
Loop While r < 2000
Color 15
Locate 10, 31
Print "Play again? (Y/N)"
Do
    a$ = InKey$
    If a$ = "y" Then Run
Loop Until a$ = "n" Or a$ = Chr$(27)
System

youwin:
Cls
Locate 10, 36
Print "You Win!"
Locate 12, 29
Print "You got the treasure,"
Locate 13, 31
Print "plus"; ndiamond; " diamonds."
t = Timer
Do
    nul$ = InKey$
Loop While Timer - t < 4
Sleep 6
System

gtdat:
bm = 0
ar = 0
en = 0

For t = 1 To items(cur) Step 2
    F$ = room$(cur, t)
    x1 = Val(Right$(F$, Len(F$) - 1))
    y1 = Val(room$(cur, t + 1))
    x2 = Val(room$(cur, t + 2))
    y2 = Val(room$(cur, t + 3))
    Select Case Left$(F$, 1)
        Case "l" 'Walls ("l" for line)
            Call Drlin(x1, y1, x2, y2)
        Case "b" 'Big blue blocks
            Call Drblock(x1, y1, x2, y2)
        Case "s" 'For putting spaces in walls.
            Locate y1, x1
            Print Chr$(32)
        Case "p" 'Plot a single point
            Locate y1, x1
            Print Chr$(219)
        Case "w" 'Warp tile
            Locate y1, x1
            Color 12
            Print Chr$(176)
            Color 7
        Case "c" 'diamonds ("d" was already used for doors.)
            If Not cn(cur) Then
                Locate y1, x1
                Color 15
                Print Chr$(4)
                Color 7
            End If
        Case "k" 'Keys
            If Not ky(cur) Then
                Locate y1, x1
                Color 14
                Print Chr$(244)
                Color 7
            End If
        Case "d" 'Doors
            If Not dr(cur) Then
                Locate y1, x1
                Color 6
                Print Chr$(8)
                Color 7
            Else
                Locate y1, x1
                Print " "
            End If
        Case "e" 'Enemies
            en = en + 1
            ex(en) = x1
            ey(en) = y1
            Locate y1, x1
            Print Chr$(234)
        Case "v" 'Continue point ("v" was a random choice)
            Color 11
            Locate y1, x1
            Print Chr$(21)
            Color 7
        Case "Q" 'End of the game marker
            Color 13
            Locate y1, x1
            Print Chr$(5)
            Color 7
        Case "a" 'arrows
            ar = ar + 1
            ax(ar) = x1
            ay(ar) = y1
            Locate y1, x1
            If Screen(y1, x1 - 1) <> 32 Then
                Print Chr$(16)
                adr(ar) = 1
            ElseIf Screen(y1, x1 + 1) <> 32 Then
                Print Chr$(17)
                adr(ar) = -1
            Else
                Print Chr$(17)
                adr(ar) = (x1 >= 40) - (x1 < 40)
            End If
        Case "m" 'boMbs
            bm = bm + 1
            bx(bm) = x1
            by(bm) = y1
            Locate y1, x1:
            Print Chr$(127)
        Case "n" 'miNes
            Locate y1, x1
            Print Chr$(233)
        Case "o" 'origin
            If Not og1 Then
                x = x1: y = y1: og1 = -1
            End If
    End Select
Next t
Return

loadnew:
Cls
Locate 1, 1
Color 15
Do
    Input "Enter Filename for loading (8 characters or less): "; n$
Loop While Len(n$) < 1 And Len(n$) > 8
n$ = n$ + ".dat"
Open "game.ini" For Output As #1
Print #1, n$
Close #1

Run

load:
Open n$ For Input As #1
For i = 1 To 30
    Input #1, k$
    items(i) = Val(k$)
    For j = 1 To items(i)
        Input #1, room$(i, j)
    Next j
Next i
Close
Return

Sub Drawscreen (ndiamond, cur, ky, tries)
    Color 7, 0
    Cls
    Locate 21, 1
    For t = 1 To 80: Print Chr$(178);: Next t
    For t = 1 To 80: Print Chr$(177);: Next t
    For t = 1 To 80: Print Chr$(176);: Next t
    Locate 22, 36
    Color 15
    Print "The Maze"
    Locate 22, 2
    Print "Diamonds: "; ndiamond
    Locate 22, 60
    Print "Room: "; cur
    Locate 23, 60
    Print "Keys: "; ky
    Locate 23, 2
    Print "Tries: "; tries
    Color 7
End Sub

Sub Drblock (x1, y1, x2, y2)
    Color 9
    Locate y1, x1
    For t = 0 To y2 - y1
        For r = 0 To x2 - x1
            Locate y1 + t, x1 + r
            Print Chr$(177);
        Next
    Next
    Color 7
End Sub

Sub Drlin (x1, y1, x2, y2)

    dy = y2 - y1: dx = x2 - x1: yc = y2: xc = x2

    If dx = 0 Then
        For yc = y2 To y1 Step Sgn(-dy)
            If yc > 0 And yc < 21 And xc > 0 And xc < 81 Then
                Locate yc, xc
                Print Chr$(219)
            End If
        Next yc
    Else dd = dy / dx
        For xc = x2 To x1 Step Sgn(-dx)
            tc = Int(dd * (xc - x2) + y2)
            Do While tc <> yc
                yc = yc + Sgn(-dy)
                If yc > 0 And yc < 21 And xc > 0 And xc < 81 Then
                    Locate yc, xc
                    Print Chr$(219)
                End If
            Loop
            If yc > 0 And yc < 21 And xc > 0 And xc < 81 Then
                Locate yc, xc
                Print Chr$(219)
            End If
        Next xc
    End If
End Sub

Sub Killdude (x1(), y1(), p, n)
    Locate y1(p), x1(p)
    Color 4
    Print Chr$(88)
    Play "l64o1go0cabc"
    n = n - 1
    For i = p To n
        If i < 10 Then
            x1(i) = x1(i + 1)
            y1(i) = y1(i + 1)
        End If
    Next
End Sub

Function LineofSight (x1, y1, x2, y2)

    dy = y2 - y1: dx = x2 - x1: yc = y2: xc = x2

    LineofSight = -1

    If dx = 0 And dy = 0 Then Exit Function

    If dx = 0 Then
        For yc = y2 To y1 Step Sgn(-dy)
            If yc > 0 And yc < 21 And xc > 0 And xc < 81 Then
                If Screen(yc, xc) <> 32 And Not ((yc = y1 And xc = x1) Or (yc = y2 And xc = x2)) Then LineofSight = 0
                'LOCATE yc, xc: PRINT CHR$(88)
            End If
        Next yc
    Else dd = dy / dx
        For xc = x2 To x1 Step Sgn(-dx)
            tc = Int(dd * (xc - x2) + y2 + .5)
            Do While tc <> yc
                yc = yc + Sgn(-dy)
                If yc > 0 And yc < 21 And xc > 0 And xc < 81 Then
                    If Screen(yc, xc) <> 32 And Not ((yc = y1 And xc = x1) Or (yc = y2 And xc = x2)) Then LineofSight = 0
                    'LOCATE yc, xc: PRINT CHR$(88)
                End If
            Loop
            If yc > 0 And yc < 21 And xc > 0 And xc < 81 Then
                If Screen(yc, xc) <> 32 And Not ((yc = y1 And xc = x1) Or (yc = y2 And xc = x2)) Then LineofSight = 0
                'LOCATE yc, xc: PRINT CHR$(88)
            End If
        Next xc
    End If

End Function

Sub Warp (x, y)
    Play "l64o3cego2bdfa"
    Do
        x = Int(Rnd(1) * 80) + 1
        y = Int(Rnd(1) * 20) + 1
    Loop While Screen(y, x) <> 32
End Sub

Function Whichone (xx(), yy(), x, y, n)
    For i = 1 To n
        If xx(i) = x And yy(i) = y Then Whichone = i
    Next
End Function

Meta