Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/tereshenkovav/trixie16bit
16-bit game "Trixie and diamonds" for MS-DOS, developed on QuickBasic 4.5 and NASM.
https://github.com/tereshenkovav/trixie16bit
16-bit 2d-game action-game game indie-game nasm quickbasic retrogaming singleplayer-game
Last synced: about 1 month ago
JSON representation
16-bit game "Trixie and diamonds" for MS-DOS, developed on QuickBasic 4.5 and NASM.
- Host: GitHub
- URL: https://github.com/tereshenkovav/trixie16bit
- Owner: tereshenkovav
- License: other
- Created: 2023-06-03T16:06:38.000Z (over 1 year ago)
- Default Branch: main
- Last Pushed: 2024-11-09T13:01:41.000Z (2 months ago)
- Last Synced: 2024-11-09T13:33:37.681Z (2 months ago)
- Topics: 16-bit, 2d-game, action-game, game, indie-game, nasm, quickbasic, retrogaming, singleplayer-game
- Language: BASIC
- Homepage: https://tav-developer.itch.io
- Size: 1.88 MB
- Stars: 0
- Watchers: 1
- Forks: 0
- Open Issues: 2
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# 16-битная игра "Трикси и алмазы" для MS-DOS, на основе QuickBasic 4.5 и NASM
[![YooMoney donation](https://img.shields.io/badge/Donation-Yoo.money-blue.svg)](https://yoomoney.ru/to/41001497003495)
[![Boosty](https://img.shields.io/badge/Boosty-donate-orange.svg)](https://boosty.to/ponygames)
[![Website](https://img.shields.io/badge/Website-tav--developer.itch.io-29a662.svg)](https://tav-developer.itch.io)
[![License](https://img.shields.io/badge/License-MIT0-darkgray.svg)](#)
[![Tag](https://img.shields.io/github/v/tag/tereshenkovav/Trixie16bit?color=00c2e8)](#)
[![Downloads](https://img.shields.io/github/downloads/tereshenkovav/Trixie16bit/total?color=c87bff)](#)## О проекте
Игра реализована как 16-битное приложение для реального режима MS-DOS, запуск
в эмуляторах также поддерживается.\
Задача игры - собрать на экране заданное количество алмазов, избегая контакта
с монстрами. Трикси может ходить, телепортироваться между платформами, использовать
файербол и щит. Эти действия расходуют ману.\
На высоком уровне сложности мана восстанавливается медленнее.
Игра поддерживает как клавиатуру, так и джойстик, управление осуществляется параллельно без выбора и настроек.![Trixie16bit](screen1.png) ![Trixie16bit](screen2.png)
## Состав репозитория
* `bin` - каталог контента игры (графика, звуки, тексты), также содержит исполняемые файлы
* `graphics` - иконки игры для дистрибутива и AppImage
* `setup` - скрипты создания архива для DOS, дистрибутивов/архивов для Windows, AppImage для Linux и архивов/DMG для MacOS
* `source` - исходный код игры для QuickBasic 4.5 и графическая библиотека [QbGraTools](https://github.com/tereshenkovav/QbGraTools), включенная в подкаталог engine## Инструменты сборки
Для сборки проекта нужен установленный QuickBasic 4.5 и ассемблер [NASM](https://nasm.us/).
Создание дистрибутива для Windows выполняется с помощью программы
[NSIS](https://nsis.sourceforge.io)Создание архива для Windows выполняется с помощью скриптовой утилиты построения архивов
[SmartZipBuilder](https://github.com/tereshenkovav/SmartZipBuilder)Для создания AppImage под Linux необходим инструмент сборки AppImageKit -
[appimagetool-x86_64.AppImage](https://github.com/AppImage/AppImageKit/releases)## Сборка, запуск игры и создание дистрибутивов
### Сборка
Для сборки можно использовать виртуальную машину с DOS/FreeDOS или же DOSBox, подключив в нём каталог, в котором доступны QuickBasic, NASM и файлы проекта.
Сначала надо собрать графическую библиотеку из каталога `source\engine`. Копируем все файлы
в каталог, где установлен QuickBasic, указываем в скрипте `grabuild.bat`
правильный путь к NASM (исходно он задан как `C:\NASM`), потом запускаем скрипт
`grabuild.bat`.
При правильной сборке, в каталоге появятся файлы `gratools.qlb` и `gratools.lib`.
Это скомпилированная графическая библиотека для работы с IDE QuickBasic и для получения EXE-файла игры.Теперь можно компилировать сам проект игры. Для этого надо скопировать файлы из каталога `source`
в каталог QuickBasic и запустить скрипт `build.bat`.
При правильной сборке, в каталоге появятся файлы `GAME.EXE` и `GAME_FPU.EXE`.
Первый файл предназначен для компьютеров без математического сопроцессора 8087,
второй может запускаться на любом x86-совместимом компьютере, где есть установленный сопроцессор.
Для запуска в DOSBox можно использовать любой из полученных файлов.Если необходимо открыть проект игры в QuickBasic IDE, то сначала надо скопировать
каталог `bin\data` в каталог установленного QuickBasic, после чего запустить
IDE командой, которая подгрузит графическую библиотеку.```
qb.exe /l gratools.qlb trixie.bas
```Скопированный каталог `data` позволит запускать игру в режиме отладки прямо из IDE.
### Запуск
Для запуска игры нужно скопировать полученные файлы `GAME.EXE` или `GAME_FPU.EXE`
в каталог `bin`, поcле чего запустить исполнимый файл.
В файле `data\options` можно включить опции показа FPS в игре или вывода отладочной информации,
раскомментировав соответствующие строки.### Создание дистрибутивов
**ВАЖНО**: при создании дистрибутивов, информация о версии, ветке и коммите берется
из репозитория git, поэтому все описанные ниже команды будут работать корректно
только при вызове из каталога-репозитория git и при наличии установленного git.Перед началом создания дистрибутивов нужно обязательно скопировать
бинарные файлы `GAME.EXE` и `GAME_FPU.EXE` в каталог `bin`. Для создания дистрибутивов не требуется DOS или DOSBox, они создаются в Windows и Linux.Создание архива для DOS или для DOSBox выполняется автоматически при
запуске файла `build.bat` из каталога `setup/dos`.Создание архива и дистрибутива для Windows выполняется автоматически при
запуске файла `build.bat` из каталога `setup/windows`
(может потребоваться указать путь к компилятору NSIS). И архив, и дистрибутив
включают в себя эмулятор DOSBox. Его файлы уже находятся в каталоге `setup/windows`,
дополнительно устанавливать не нужно.Создание AppImage под Linux выполняется автоматически при
запуске файла `build64.sh`, из каталога `setup/linux` если
установлен AppImageKit и исполнимый файл DOSBox находится по пути `/usr/bin/dosbox`.Создание архива приложения и образа DMG под MacOS выполняется автоматически при
запуске файла `make_app.sh`, из каталога `setup/mac`.
Необходимые файлы DOSBox уже находятся в каталоге проекта.