Владивостокский Государственный Университет Экономики и Сервиса Кафедра УТВЕРЖДАЮ Заведующий кафедрой ________ Н. Н. ___”_______1998 г. Отчет По лабораторной работе Руководитель _______________ Глытина К. У Исполнитель студент ИС-97 _______________ Гавриленко А. С. Находка 1998 г. Постановка задачи. Цель: Создать законченный вариант игры на ловкость “Змейка” Законченный вариант игры змейка должен содержать:
“Змейку”, которая может двигаться в ограниченной плоскости. Маневрами “Змейки” должен управлять играющий. “Змейка” должна увеличиваться в размерах при столкновении с “яблоком” и погибать при столкновении с “бомбой”, при пересечении самой себя и при выходе за границы плоскости заданной программистом.
“Яблоко” или другой объект, при столкновении с которым “Змейка” “съедает” его(увеличивается в длину в зависимости от условий заданных программистом.
“Бомба” или иной объект при столкновении с которым змейка погибает.
P. S. Необязательным условием(по желанию учащегося), “змейка” может управляться мышкой(с помощью клавиш на форме), игра может иметь счетчик набранных очков, таблицу лучших игроков, которая может сохранятся и считываться из файла, а также другие элементы которые увеличивают играбельность игры. Алгоритм Описываются переменные и константы(Dim, Const) Выбор начальных координат случайным образом(Rnd()). Прорисовка начального положения. (Pset(x, y)) Генерация на поле яблок и бомб случайным образом(Rnd()).
Проверка: не появилось ли яблоко или бомба на черве, а также друг на друге. Управление “Змейкой” с клавиатуры и мышкой.
Проверка: “не укусила” ли “змейка сама себя”, если укусила выводится информационное окно (Инфоформационнаяформа), в противном случае переходим к следующему пункту.
Проверка: “не съела” ли “змейка” “яблоко” если съела, то наращиваем ей хвост и переходим к пункту 3), в противном случае см. Следующий пункт. Проверка: “не съела” ли “змейка” “бомбу”, если съела, то выводится информационное окно (Инфоформационнаяформа), в противном случае переходим к следующему пункту. Перерисовка “Змейки”
P. S. За движение “Змейки” появление “яблок” и “бомб” отвечают три разных таймера. Это было использовано для того, чтобы скорость движения “змейки” была постоянной, а также чтобы “яблоко” и “бомба” появлялись на поле в разное время с разным периодом появления.
Не исключено, что в последующем в данную программу будут добавлены другие объекты, а также возможность создания таблицы лучших игроков, с возможностью хранения этой таблицы в файле, который может быть считан и записан, а так же перезаписан. Код программы: Форма_Змейка '-------Описание переменных------ Option Explicit Dim Змейка() As Змея Dim LastPos As Змея Dim Apple As Змея Dim Bomba As Змея Dim i, j, Длина As Integer Dim XDir, YDir As Integer Dim FirstXPos, FirstYPos As Integer Dim Проверочная1 As Byte Dim Проверочная2 As Single Dim НЛ As String '-------Начальные присвоения-------
Const TIC = 1 'Период таймера Const BackCollor = &H8000000F 'Цвет заднего плана Const WormCollor = &H80& 'Цвет Змейки Const AppleCollor = &HFF00& 'Цвет яблока Const BombaCollor = &H80000012 'Цвет бомбы
Const Толщина = 10 'Толщина червяка Const НачДлина = 5 'Начальная длина Змейки Const ПриращениеДлины = 3 'Приращение длины Змейки ------------------------------------------------------------------------------------------------ Public Sub Form_Load() Поле. BackColor = BackCollor Поле. DrawWidth = Толщина Длина = НачДлина ReDim Preserve Змейка(1 To НачДлина) '------Начальное положение----- FirstXPos = 5 + Int(Rnd() * 41) FirstYPos = 5 + Int(Rnd() * 41) For i = 1 To 5 Змейка(i). XPos = FirstXPos Змейка(i). YPos = FirstYPos + i Next i НачПоложение '------Направление движения----- XDir = 0 YDir = -1 'Вверх '------Генерация Яблок и Бомб--- AppleGen BombaGen Taimer. Interval = TIC End Sub '---Прорисовка начального положения-- Private Sub НачПоложение() Поле. ForeColor = WormCollor СчетИгры. Caption = Длина For i = 1 To Длина Поле. PSet (Змейка(i). XPos * 100, Змейка(i). YPos * 100) Next i End Sub
------------------------------------------------------------------------------------------------ Private Sub Taimer_Timer() Движение Перерисовка End Sub
------------------------------------------------------------------------------------------------ Private Sub Движение() НЛ = Chr(10) & Chr(13) 'Перевод строки Поле. AutoRedraw = True Поле. DrawWidth = Толщина LastPos = Змейка(Длина) For i = Длина To 2 Step -1 Змейка(i) = Змейка(i - 1) Next i Змейка(1). XPos = Змейка(1). XPos + XDir Змейка(1). YPos = Змейка(1). YPos + YDir '------Не вышел ли за пределы поля----- On Error GoTo ВышелЗаПределы Проверочная1 = Змейка(1). XPos - 1 Проверочная1 = Змейка(1). YPos - 1 Проверочная1 = Змейка(1). XPos + 206 Проверочная1 = Змейка(1). YPos + 206 '------Не укусил ли самого себя----- УкусилСамогоСебя: For i = 2 To Длина
If Змейка(1). XPos = Змейка(i). XPos And Змейка(1). YPos = Змейка(i). YPos Then Taimer. Interval = 0 ИнформационнаяФорма. ИнфоПоле. Caption = НЛ & _ "ВАША ЗМЕЙКА" & НЛ & _ "САМА СЕБЯ УКУСИЛА" & НЛ & НЛ & _ "Длина змейки " & Длина ИнформационнаяФорма. Show Форма_Змейка. Enabled = False End If Next i '-----Не наткнулся ли на яблоко---- On Error GoTo Наткнулась1
Проверочная2 = 1 / (Abs((Змейка(1). XPos - Apple. XPos)) + Abs((Змейка(1). YPos Apple. YPos))) '-----Не наткнулась ли на бомбу----- On Error GoTo Наткнулась2
Проверочная2 = 1 / (Abs((Змейка(1). XPos - Bomba. XPos)) + Abs((Змейка(1). YPos Bomba. YPos))) Exit Sub '----------------Обравотка столкновений-------------- ВышелЗаПределы: Taimer. Interval = 0 ИнформационнаяФорма. ИнфоПоле. Caption = НЛ & _ "ВАША ЗМЕЙКА" & НЛ & _ "ВЫШЛА ЗА ПРЕДЕЛЫ ПОЛЯ" & НЛ & НЛ & _ "Длина змейки " & Длина ИнформационнаяФорма. Show Форма_Змейка. Enabled = False Exit Sub Наткнулась1: Длина = Длина + ПриращениеДлины ReDim Preserve Змейка(1 To Длина) '-------Перемещаем хвост в конец------ For i = Длина To ПриращениеДлины + 1 Step -1 Змейка(i) = Змейка(i - ПриращениеДлины) Next i 'Добавляем в голову по направлению движения For i = ПриращениеДлины To 1 Step -1 Змейка(i). XPos = Змейка(i + 1). XPos + XDir Змейка(i). YPos = Змейка(i + 1). YPos + YDir Next i AppleGen НачПоложение Exit Sub Наткнулась2: Taimer. Interval = 0 ИнформационнаяФорма. ИнфоПоле. Caption = НЛ & _ "ВАША ЗМЕЙКА" & НЛ & _ "СЪЕЛА БОМБУ" & НЛ & НЛ & _ "Длина змейки " & Длина ИнформационнаяФорма. Show Форма_Змейка. Enabled = False Exit Sub End Sub
------------------------------------------------------------------------------------------------ Private Sub Перерисовка() '------Рисуем змейку------ Поле. ForeColor = BackCollor Поле. PSet (LastPos. XPos * 100, LastPos. YPos * 100) Поле. ForeColor = WormCollor Поле. PSet (Змейка(1). XPos * 100, Змейка(1). YPos * 100)
Поле. PSet (Змейка(Длина). XPos * 100, Змейка(Длина). YPos * 100) '------Рисуем Яблоко------ Поле. ForeColor = AppleCollor Поле. PSet (Apple. XPos * 100, Apple. YPos * 100) '------Рисуем бомбу------- Поле. ForeColor = BombaCollor Поле. PSet (Bomba. XPos * 100, Bomba. YPos * 100) End Sub
------------------------------------------------------------------------------------------------ Private Sub TaimerApple_Timer() TaimerApple. Interval = (5 + Int(Rnd() * 11)) * 1000 Поле. ForeColor = BackCollor Поле. PSet (Apple. XPos * 100, Apple. YPos * 100) AppleGen End Sub
------------------------------------------------------------------------------------------------ Private Sub TaimerBomba_Timer() TaimerBomba. Interval = (5 + Int(Rnd() * 11)) * 1000 Поле. ForeColor = BackCollor Поле. PSet (Bomba. XPos * 100, Bomba. YPos * 100) BombaGen End Sub
------------------------------------------------------------------------------------------------ Private Sub AppleGen() Метка1: Apple. XPos = 1 + Int(Rnd() * 49) Apple. YPos = 1 + Int(Rnd() * 49) i = 1 Do While i
If Apple. XPos = Змейка(i). XPos And Apple. YPos = Змейка(i). YPos Then GoTo Метка1 Exit Do End If i = i + 1 Loop End Sub
------------------------------------------------------------------------------------------------ Private Sub BombaGen() Метка2: Bomba. XPos = 1 + Int(Rnd() * 49) Bomba. YPos = 1 + Int(Rnd() * 49) i = 1 Do While i
If Bomba. XPos = Змейка(i). XPos And Bomba. YPos = Змейка(i). YPos Or Bomba. XPos = Apple. XPos And Bomba. YPos = Apple. YPos Then GoTo Метка2 Exit Do End If i = i + 1 Loop End Sub
------------------------------------------------------------------------------------------------ '-----Обработка клавиш управления-----
Private Sub поле_KeyDown(KeyCode As Integer, Shift As Integer) Select Case KeyCode Case 38 'вверх XDir = 0 YDir = -1 Case 40 'вниз XDir = 0 YDir = 1 Case 37 'влево XDir = -1 YDir = 0 Case 39 'вправо XDir = 1 YDir = 0 Case 27 'ESC End Case 113 'F2-игра Форма_Змейка. Enabled = True Форма_Змейка. Form_Load ИнформационнаяФорма. Hide End Select End Sub
------------------------------------------------------------------------------------------------ ‘Обработка нажатий кнопок Private Sub Up_Click() XDir = 0 YDir = -1 End Sub Private Sub Down_Click() XDir = 0 YDir = 1 End Sub Private Sub Left_Click() XDir = -1 YDir = 0 End Sub Private Sub Right_Click() XDir = 1 YDir = 0 End Sub Private Sub Command1_Click() End End Sub Private Sub Command2_Click() Форма_Змейка. Enabled = True Форма_Змейка. Form_Load ИнформационнаяФорма. Hide End Sub ИнформационнаяФорма Dim НЛ As String
------------------------------------------------------------------------------------------------ Private Sub Avtor_Click() НЛ = Chr(10) & Chr(13)
AboutAvtor. Label4. Caption = "Все права защищены, " & НЛ & _ "использование в комерческих целях преследуется по закону" ИнформационнаяФорма. Enabled = False AboutAvtor. Show End Sub
------------------------------------------------------------------------------------------------ ‘Обработка нажатий кнопок Private Sub Exit_Click() КнопкаВыход_Click End Sub Private Sub NewGame_Click() КнопкаПовторить_Click End Sub Private Sub КнопкаВыход_Click() Unload Форма_Змейка Unload Me End Sub Private Sub КнопкаПовторить_Click() Форма_Змейка. Enabled = True Форма_Змейка. Form_Load ИнформационнаяФорма. Hide End Sub AboutAvtor ‘Закрытие формы щелчко кнопки мышы по фотографии Private Sub Image1_Click() ИнформационнаяФорма. Enabled = True Unload Me End Sub Module1 Option Explicit ‘Создаем новый тип переменной Public Type Змея XPos As Integer YPos As Integer End Type