Difference between revisions of "Game Distribution (Українська)"

m (translated the section on AppImage)
(seems done :))
Line 226: Line 226:
  
 
== Android ==
 
== Android ==
=== Compiling from source ===
+
=== Компіляція з початкового коду ===
Firstly clone the android LÖVE project, specifying which branch to use:  
+
По-перше зклонуйте проєкт LÖVE:
 
<source lang='bash'>git clone https://github.com/love2d/love-android</source>
 
<source lang='bash'>git clone https://github.com/love2d/love-android</source>
Then, download the Android SDK (API 28) and NDK. For the NDK, r16 and later is known to work. Older version is untested.
+
Після цього завантажте Android SDK (API 28) та NDK. Відомо, що для NDK працює версія r16 та новіше. Робота на старіших версіях не тестувалась.
  
Set these environment variables
+
Встановіть наступні змінні середовища:
* <code>ANDROID_HOME</code> to your Android SDK location.
+
* <code>ANDROID_HOME</code> має містити шлях до Android SDK.
* <code>ANDROID_NDK_HOME</code> to your Android NDK location.
+
* <code>ANDROID_NDK_HOME</code> має містити шлях до Android NDK.
  
Put the game (game.love) in the directory (project)/app/src/main/assets (if this directory don't exist create it).
+
Скопіюйте гру (game.love) в директорію (проєкт)/app/src/main/assets (якщо такої директорії не існує, створіть її).
  
For Linux or macOS systems it may be necessary set the executable permission:
+
В системах Linux та macOS, можливо, буде потрібно встановити дозволи на виконання програми:
 
<source lang="bash">chmod +x gradlew</source>
 
<source lang="bash">chmod +x gradlew</source>
  
And finally to generate the apk, do:
+
Нарешті, щоб створити файл apk, виконайте:
 
<source lang='bash'>./gradlew assemble</source>
 
<source lang='bash'>./gradlew assemble</source>
  
The apk will be in (project)/app/build/outputs/apk/
+
Файл .apk буде в директорії (проєкт)/app/build/outputs/apk/
  
For more information see the [https://bitbucket.org/MartinFelis/love-android-sdl2/wiki/Home Android wiki].
+
Більше інформації можна знайти в [https://bitbucket.org/MartinFelis/love-android-sdl2/wiki/Home wiki про Löve для Android] (англійською).
  
=== Using APKTool ===
+
=== Використання APKTool ===
Please see [[Game Distribution/APKTool]] for more information.
+
Див. інструкції на сторінці {{translated link|Game Distribution/APKTool|Українська}}.
  
 
== iOS ==
 
== iOS ==
  
Basic instructions for iOS (without fusing) are available at [[Getting Started (Українська)#iOS]].
+
Базові інструкції для iOS (без приєднання гри) доступні в статті [[Getting Started (Українська)#iOS]].
  
To '''fuse''' your game into the LÖVE engine:
+
Щоб '''приєднати''' свою гру до рушія LÖVE:
# Get iOS source code from [http://love2d.org love2d.org].
+
# Завантажте початковий код для iOS з [http://love2d.org love2d.org].
# Open platform/xcode/love.xcodeproj with Xcode.
+
# Відкрийте platform/xcode/love.xcodeproj в Xcode.
# Select love-ios target (not love-macosx)
+
# Оберіть мету love-ios (не love-macosx)
# Select '''Build Phases''' of the 'love-ios' target and add your 'game.love' file into '''Copy Bundle Resources'''.
+
# Оберіть '''Build Phases''' (Фази збірки) цілі 'love-ios', і додайте свій файл 'game.love' в '''Copy Bundle Resources''' (Копіювати ресурси пакунку).
# Build the project.
+
# Зберіть проєкт.
# Your game should appear on your iOS device as an app.
+
# Ваша гра має з'явитися на вашому пристрої iOS у вигляді застосунку.
  
If you can't find the relevant XCode UI elements, you can refer to [https://youtu.be/MsYanwcU42E video tutorial on YouTube].
+
Якщо ви не можете знайти потрібні елементи в інтерфейсі XCode, відкрийте [https://youtu.be/MsYanwcU42E відеоурок на YouTube] (англ.).
  
== Distribution on the web ==
+
== Розповсюдження в web ==
  
Publishing as a HTML5 or JavaScript game is possible thanks to [https://github.com/TannerRogalsky/love.js TannerRogalsky/love.js]. Threads for example are not supported though and playback of course depends on the browser.
+
Дякуючи [https://github.com/TannerRogalsky/love.js TannerRogalsky/love.js], ігри можна запускати в браузері з підтримкою HTML5 та JavaScript. Потоки (threads) недоступні, і робота залежить від браузера.
  
== Community Tools ==
+
== Інструменти від спільноти ==
  
There are a few tools developed by the community to help with game distribution.
+
Спільнота розробників створила декілька інструментів, які допомагають розповсюджувати ігри.
* [https://github.com/MisterDA/love-release love-release] ([https://love2d.org/forums/viewtopic.php?t=75387 forum]), a Lua script that automates game distribution. Supports Windows, macOS, Debian, Linux, with much more features.
+
* [https://github.com/MisterDA/love-release love-release] ([https://love2d.org/forums/viewtopic.php?t=75387 на форумі], англ.), скрипт на Lua, який автоматизує створення пакунків для гри. Підтримує Windows, macOS, Debian, Linux, і має багато опцій.
* [https://github.com/camchenry/boon boon] ([https://love2d.org/forums/viewtopic.php?t=86573 forum]), a multi-plateform, easy to use tool supporting Windows, macOS, Linux.
+
* [https://github.com/camchenry/boon boon] ([https://love2d.org/forums/viewtopic.php?t=86573 на форумі], англ.), багатоплатформовий простий інструмент, якій підтримує Windows, macOS, Linux.
* [https://love2d.org/forums/viewtopic.php?f=3&t=80565 Love Distrubution Pack][sic], a windows-only tool that can create .love files and exes.
+
* [https://love2d.org/forums/viewtopic.php?f=3&t=80565 Love Distrubution Pack][sic], інструмент тільки для Windows, який лише дозволяє створювати файли .love та виконувані exe-файли.
* [https://www.love2d.org/forums/viewtopic.php?f=5&t=30259 love-dist], a windows-only tool that can [[LuaC]] your files and create an exe.
+
* [https://www.love2d.org/forums/viewtopic.php?f=5&t=30259 love-dist], інструмент тільки для Windows, який компілює ваші ігри через {{translated link|LuaC|Українська}} і створює exe-файл.
  
[[Category:LÖVE]]
+
[[Category:LÖVE (Українська)]]
  
 
== Іншими мовами ==
 
== Іншими мовами ==
 
{{i18n|Game Distribution}}
 
{{i18n|Game Distribution}}

Revision as of 09:21, 31 January 2020

Коли ви зробите свою гру, ви, безумовно, захочете поділитися нею з іншими. Для цього звичайно треба створити файл .love. Потім можна або передати цей файл іншим (щоб зіграти в таку гру, гравцям потрібно спочатку встановити LÖVE), або створити на його основі пакети для конкретних платформ.

Ось найбільш зручні способи розповсюдження ігор на різних платформах (для всіх них потрібен файл .love):

Створення файлу .love

Зверніть увагу, що в деяких операційних системах великі і малі літери в назвах файлів та директорій вважаються різними літерами. Щоб у вас не було проблем, переконайтеся, що назви файлів в коді та на диску написані однаково.

Щоб створити файл .love, треба створити файл zip усієї директорії з грою. Переконайтеся, що файл main.lua знаходиться в корені архіву. Тобто якщо ваші файли зберігаються так:

   <somedir>\SuperGame\gfx\character.png
   <somedir>\SuperGame\main.lua
   <somedir>\SuperGame\conf.lua

то в zip-архіві вони мають зберігатися так:

   gfx\character.png
   main.lua
   conf.lua

Не треба включати директорію гри SuperGame\.

Після створення .zip-файлу просто перейменуйте його з .zip в .love, і все готово!

Якщо ви працюєте на системі, яка не розрізняє великі та малі літери в іменах файлів (наприклад, в Windows), рекомендується перенести свій файл .love в іншу директорію, запустити його звідти і протестувати гру. Таким чином можна знайти проблеми з різними іменами файлів, з якими можуть зіштовхнутися інші гравці або гравчині. Якщо ви запускатимете гру в тій же директорії, то навіть якщо .love не знайде в архіві якісь файли, він відкриє їх копію з диску. Для тестування зручно перенести файл .love в нову директорію всередині директорії гри, наприклад, love/MyGame.love.

Створення пакетів на різних платформах

Windows

В Windows вбудована можливість створення zip-файлів через контекстне меню. Детальніше див. в інструкції Запакування та розархівування файлів.

macOS

В директорії гри оберіть файли гри та під-директорії, натисніть правою кнопкою миші/з затиснутим Ctrl, після чого оберіть Compress n items (Запакувати N елементів). Після цього перейменуйте створений файл .zip, щоб в нього було закінчення .love ending.

Альтернативний варіант — використати термінал. Зайдіть в папку гри та виконайте таку команду:

   zip -9 -r SuperGame.love .

Linux

В командному рядку, якщо вашою активною директорією є SuperGame/, файл .love можна створити таким чином:

   zip -9 -r SuperGame.love .

Створення виконуваного файлу для Windows

Після запакування гри в файл .love, можна створити виконуваний файл, щоб гра запускалася напряму.

Для цього потрібно додати зміст вашого файлу .love до файлу love.exe з офіційного .zip-файла LÖVE. Об'єднаний виконуваний файл і буде використовуватися для запуску гри.

Коли у вас буде об'єднаний виконуваний файл гри, його можна буде запакувати разом з файлами DLL та іншими файлами з офіційного .zip-файлу LÖVE в новий .zip-файл, і передавати його кому завгодно.

Зауваження: Не у всіх є 64-бітна версія Windows, тому краще або створити і 32-, і 64-бітну версію вашої гри, або розповсюджувати тільки 32-бітну версію.

Інструкції для різних платформ

Windows

Щоб створити виконуваний файл в Windows, виконайте в командному рядку таку команду:

   copy /b love.exe+SuperGame.love SuperGame.exe

Зауваження: Можливо, вам доведеться виконати цю команду як адміністратор комп'ютера. Для цього можна зайти в папку Windows\System32, натиснути правою кнопкою миші на файл cmd.exe і вибрати варіант Run as administrator (Запустити як адміністратор). Після цього потрібно набрати cd C:\Program Files\LOVE\ (замініть це на шлях до директорії з LÖVE) і виконати команду там.

Альтернативний спосіб: можна створити файл .bat (наприклад, create_game_exe.bat), записати в ньому такий текст:

   copy /b love.exe+%1 "%~n1.exe"

і просто перетягнути ваш файл SuperGame.love на .bat-файл — після цього буде створено файл SuperGame.love.exe, який можна розповсюджувати.

Якщо ви використовуєте PowerShell замість cmd, то команда буде трошки інакшою:

   cmd /c copy /b love.exe+SuperGame.love SuperGame.exe

Цей метод створює приєднану (fused) до програми гру.

Значок для Windows

Значок своєї гри можна змінити програмами на кшталт безкоштовного Resource Hacker (англ.).

Є відеоурок (англ.) та покрокова інструкція (англ.).

Linux / macOS

В Linux та macOS можна створити виконуваний файл для Windows з командного рядка.

Спочатку завантажте офіційний 32-бітний або 64-бітний виконуваний файл в архіві ZIP (zipped, не встановлювач) з https://www.love2d.org/. 32-бітні ігри можна виконувати і на системах з 64-бітним Windows, але навпаки робити не можна. Тому, щоб тратити менше часу, для невеличких ігор вистачить тільки 32-бітної версії.

Після цього в командному рядку/терміналі виконайте таку команду:

   cat love.exe SuperGame.love > SuperGame.exe

щоб отримати ігровий виконуваний файл SuperGame.exe.

Для розповсюдження гри треба разом з виконуваним файлом додати файли .dll з тої директорії, в якій був файл love.exe (важливо не переплутати 32-бітні .dll-файли з 64-бітними). Якщо їх не додати, при запуску SuperGame.exe в Windows буде виводитися помилка.

В результаті ваш фінальний архів має виглядати приблизно так:

  • SDL2.dll
  • OpenAL32.dll (зауваження: 64-бітній версія цього файла відрізняється від 32-бітної, хоч назва в нього і залишиться 'OpenAL32.dll')
  • SuperGame.exe
  • license.txt (зауваження: згідно з ліцензією, її обов'язково треба копіювати при копіюванні файлів)
  • love.dll
  • lua51.dll
  • mpg123.dll
  • msvcp120.dll
  • msvcr120.dll

Створення застосунку macOS

Коли ви підготувати файл .love зі своєї грою, його можна зробити доступним для гравців та гравчинь з системою macOS, виконавши описані кнопки (також є відеоурок англійською):

  1. Завантажте і розпакуйте версію LÖVE для Mac з the домашньої сторінки LÖVE
  2. Переіменуйте love.app в SuperGame.app
  3. Скопіюйте SuperGame.love в SuperGame.app/Contents/Resources/ (в macOS натисніть правою кнопкою миші/утримуючи Ctrl в оберіть "Показати зміст пакунку" / "Show Package Content"). В результаті гра буде працювати в об'єднаному режимі.
  4. Змініть SuperGame.app/Contents/Info.plist (див. нижче)
  5. Запакуйте папку SuperGame.app в формат ZIP (напр. SuperGame_osx.zip) і розповсюджуйте її. Включіть флаг -y zip-архіву, щоб зберегти символічні посилання.

Коли будете міняти SuperGame.app/Contents/Info.plist, обов'язково змініть текст в наступних XML-тегах:

  • CFBundleIdentifier
  • CFBundleName

і видаліть розділ UTExportedTypeDeclarations, щоб macOS не зв'язав .love-файли інших ігор з вашою грою. В цілому зміни мають виглядати приблизно так:

Оригінальний Info.plist Змінений Info.plist
   ...
   <key>CFBundleIdentifier</key>
   <string>org.love2d.love</string>
   ...
   <key>CFBundleName</key>
   <string>LÖVE</string>
   ...
   <key>NSPrincipalClass</key>
   <string>NSApplication</string>
   <key>UTExportedTypeDeclarations</key>
   <array>
   ...
   </array>
   </dict>
   </plist>
   ...
   <key>CFBundleIdentifier</key>
   <string>com.SuperCompany.SuperGame</string>
   ...
   <key>CFBundleName</key>
   <string>SuperGame</string>
   ...
   <key>NSPrincipalClass</key>
   <string>NSApplication</string>
   </dict>
   </plist>

Розповсюдження в Linux

В Linux поки що немає простого способу розповсюдження ігор. Основний підіх — дати посилання на офіційні пакунки LÖVE на https://www.love2d.org. Після встановлення LÖVE файли .love звичайно запускаються автоматично, або такою командою в командному рядку:

love SuperGame.love

Обов'язково додайте файл conf.lua і вкажіть в ньому використану версію LÖVE.

function love.conf(t)
    t.version = "11.2"
end

Часта помилка — спроба приєднати до лінуксової програми файл .love:

cat /usr/bin/love SuperGame.love > SuperGame
chmod a+x ./SuperGame

Вважайте, що хоч `SuperGame` і запуститься на вашому комп'ютері, в інших дистрибутивах Linux може бути інша архітектура або інші версії бібліотек, тому є велика імовірність, що на інших комп'ютерах з Linux вона не запуститься.

Нестабільний метод для Linux

Поки що не гарантується, що цей метод буде працювати у всіх можливих ситуаціях, але можна попробувати його для розповсюдженні ігор в Linux.

  1. Завантажте актуальну версію LÖVE для Linux (з розширенням .tar.gz), або x86_64, або i686. Сторінка завантаження (англ.)
  2. Розпакуйте файл .tar.gz. Для цього можна або натиснути на нього правою кнопкою миші і вибрати «Розпакувати файл» (Extract file), або розпакувати його з командного рядку:
     tar -xvzf love.tar.gz
    
  3. Перенесіть свій файл game.love в директорію, яка з'явилася після розпакування.
  4. Відредагуйте файл love і замініть "$@" на "${LOVE_LAUNCHER_LOCATION}/game.love"

Debian

Архів Debian має правила включення ігор на LÖVE. Навіть якщо ви не плануєте додавати гру в цей архів, ви можете використовувати їх інструкції.

Створення пакетів Love2d (англ.)

Пакунки AppImage

Формат AppImage дозволяє створити пакунок з програмою, який можна буде використовувати на багатьох різних системах (основних операційних системах, дистрибутивах) без змін. Весь набір інструментів для нього можна завантажити тут (англ.).

Щоб створити пакунок AppImage для гри потрібно зібрати всі бібліотеки та файли, від яких залежить LÖVE. Це можно проста зробити програмою CARE (вона доступна в репозитаріях Ubuntu), виконавши таку коману:

care -o love.tar.gz love

.

Ця програма створить архів, в якому буде виконуваний файл love та файли, від яких він залежить, і інші пов'язані файли, які зберігаються в вашій системі.

По-друге, необхідно «приєднати» гру до файла .love таким чином, як показано вижче. Після цього файли в директорії виглядатимуть так:

Application Directory/
├── <game name>.desktop  --> В цьому файлі записаний шлях до значка програми,
│                            назва програми і команда для її викнонання.
├── <game name>.png      --> Значок вашої програми
└── usr/
    ├── bin/    --> Сюди треба покласти об'єднаний виконуваний файл
    ├── lib/    --> Сюди треба покласти бібліотеки
    └── share/  --> Сюди треба покласти ваші (або від LÖVE) файли даних (та інші речі), якщо вони є

На останньому кроці директорію треба перетворити в AppImage, використовуючи AppImageAssistant з набору інструментів. Більше інформації можна знайти в документації до AppImage (англ.).

Android

Компіляція з початкового коду

По-перше зклонуйте проєкт LÖVE:

git clone https://github.com/love2d/love-android

Після цього завантажте Android SDK (API 28) та NDK. Відомо, що для NDK працює версія r16 та новіше. Робота на старіших версіях не тестувалась.

Встановіть наступні змінні середовища:

  • ANDROID_HOME має містити шлях до Android SDK.
  • ANDROID_NDK_HOME має містити шлях до Android NDK.

Скопіюйте гру (game.love) в директорію (проєкт)/app/src/main/assets (якщо такої директорії не існує, створіть її).

В системах Linux та macOS, можливо, буде потрібно встановити дозволи на виконання програми:

chmod +x gradlew

Нарешті, щоб створити файл apk, виконайте:

./gradlew assemble

Файл .apk буде в директорії (проєкт)/app/build/outputs/apk/

Більше інформації можна знайти в wiki про Löve для Android (англійською).

Використання APKTool

Див. інструкції на сторінці Game Distribution/APKTool (англ.).

iOS

Базові інструкції для iOS (без приєднання гри) доступні в статті Getting Started (Українська)#iOS.

Щоб приєднати свою гру до рушія LÖVE:

  1. Завантажте початковий код для iOS з love2d.org.
  2. Відкрийте platform/xcode/love.xcodeproj в Xcode.
  3. Оберіть мету love-ios (не love-macosx)
  4. Оберіть Build Phases (Фази збірки) цілі 'love-ios', і додайте свій файл 'game.love' в Copy Bundle Resources (Копіювати ресурси пакунку).
  5. Зберіть проєкт.
  6. Ваша гра має з'явитися на вашому пристрої iOS у вигляді застосунку.

Якщо ви не можете знайти потрібні елементи в інтерфейсі XCode, відкрийте відеоурок на YouTube (англ.).

Розповсюдження в web

Дякуючи TannerRogalsky/love.js, ігри можна запускати в браузері з підтримкою HTML5 та JavaScript. Потоки (threads) недоступні, і робота залежить від браузера.

Інструменти від спільноти

Спільнота розробників створила декілька інструментів, які допомагають розповсюджувати ігри.

  • love-release (на форумі, англ.), скрипт на Lua, який автоматизує створення пакунків для гри. Підтримує Windows, macOS, Debian, Linux, і має багато опцій.
  • boon (на форумі, англ.), багатоплатформовий простий інструмент, якій підтримує Windows, macOS, Linux.
  • Love Distrubution Pack[sic], інструмент тільки для Windows, який лише дозволяє створювати файли .love та виконувані exe-файли.
  • love-dist, інструмент тільки для Windows, який компілює ваші ігри через LuaC (англ.) і створює exe-файл.

Іншими мовами