Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/servb/pph
Pocket Palm Heroes – a turn-based strategy made in the style and feel of the old-school "Heroes of Might and Magic" game. Native full version: https://github.com/SerVB/pph-native
https://github.com/servb/pph
game korge kotlin pocket-palm-heroes
Last synced: 15 days ago
JSON representation
Pocket Palm Heroes – a turn-based strategy made in the style and feel of the old-school "Heroes of Might and Magic" game. Native full version: https://github.com/SerVB/pph-native
- Host: GitHub
- URL: https://github.com/servb/pph
- Owner: SerVB
- License: apache-2.0
- Created: 2018-03-31T09:17:09.000Z (over 6 years ago)
- Default Branch: master
- Last Pushed: 2021-07-18T17:16:08.000Z (over 3 years ago)
- Last Synced: 2024-10-04T13:18:16.758Z (about 1 month ago)
- Topics: game, korge, kotlin, pocket-palm-heroes
- Language: Kotlin
- Homepage: https://servb.github.io/pph/
- Size: 15.6 MB
- Stars: 22
- Watchers: 5
- Forks: 4
- Open Issues: 14
-
Metadata Files:
- Readme: README.md
- License: LICENSE.txt
Awesome Lists containing this project
README
# Pocket Palm Heroes [![Discord](https://img.shields.io/discord/563755662866251786.svg?label=Join%20PPH%20on%20Discord!)](https://discord.gg/Rw95NQx) ![Build](https://github.com/SerVB/pph/workflows/Build/badge.svg) [![Deploy to GitHub Pages](https://github.com/SerVB/pph/actions/workflows/gh-pages.yml/badge.svg)](https://servb.github.io/pph/)
This project tries to bring good old Palm Heroes/Pocket Heroes back to life. The work was started in 2017.
![Screenshots image](pictures/good-old-gif.gif)
Pocket Palm Heroes is an original turn-based strategy for different devices, that is made in the style and feel of the
old-school "Heroes of Might and Magic" game. Pocket Palm Heroes plunges you into the atmosphere of exciting fantasy
adventures and epic battles! Lead your heroes as a barbarian orc chief, a noble knight, a mighty wizard, a fast
beautiful sorceress, a warlock, or a creepy undead necromancer! As your kingdom grows in size, and your heroes get more
powerful, you will discover new places, learn new skills and magic, and fight different monsters!## Play online!
It's available at GitHub Pages: .
## Running from sources
To run the game, clone the repo and execute the following commands:
```shell
# Pack resources (needed only once or after changes in resources):
./gradlew :packResources # for Linux/Mac
.\gradlew.bat :packResources # for Windows
``````shell
# Run app:
./gradlew :runJvm # for Linux/Mac
.\gradlew.bat :runJvm # for Windows
```Java needs to be installed on the computer.
## What we have
### Sources of different versions
Unsurprisingly, this project is based on the following source codes:
1. (available under Apache 2.0 license) — 1.04 beta. Can be compiled
even in Visual Studio 2019 (Community) but with some effort (feel free to ask for help at Discord if you want to
compile them).
1. (available under Apache 2.0 license) — seems to be 1.03. Can't
be compiled because of lack of some files. Also, there is many code that is related to licence registration (take a
look at commits).The sources are old (not the latest 1.05). Let's primarily use the 1.04 beta version.
### Change logs
Change logs are needed to fix the old sources and upgrade the version to the final known one — 1.05.
* [0.02, 0.03, 0.041](http://hpc.ru/soft/software.phtml?id=9712).
* [1.01, 1.03](http://hpc.ru/soft/software.phtml?id=18685).
* [1.04, 1.05](https://4pda.ru/forum/index.php?showtopic=104972).### File prefixes
Many source files has prefixes.Prefix|Possible description
---|---
gxl|Main framework
xxl|Extensions for the main framework
xau|Audio compression
xjp|Image compression
he|"Helium" library### Game menus
Menu classes|Description|Menu items
---|---|---
`MenuView`/`iMainMenuDlg`|Main menu screen|`TRID_MENU_NEWGAME`, `TRID_MENU_LOADGAME`, `TRID_MENU_HIGHSCORE`, `TRID_MENU_CREDITS`, `TRID_MENU_EXITGAME`
`GameMenuDlg`/`iGameMenuDlg`|Small menu dialog in the corner of the screen during the game|Settings, Save game, Main menu, Quit, Return to game## What we do
Port the existing sources to Kotlin. Use [KorGE](https://korge.org/) (available under Apache 2.0 license) to draw
picture, process user input, and provide binaries for different platforms.### Progress
The progress can be seen under the [Issues](https://github.com/anonymous-frog-studio/pph/issues) tab.
There are some screencasts of what's working:
* [Progress bar](https://youtu.be/gDINi7vj29k).
* [Main menu](https://youtu.be/jZVkJDCNsCQ).
* [Language selector and credits](https://youtu.be/2puY83JPWbw).### Practices
There are some practices of rewriting C++ code to JVM-related code.
#### Constant references
Many objects are passed to functions as constants. To archive this in Kotlin, it's needed to write an interface with
constant (read-only) methods and another interface or class with other methods that extends/implements the constant
interface. The interface should have the "I" prefix (from "Immutable"). You can find many examples in the ported
sources.Maybe Kotlin will have such a concept in the future: [KT-44173](https://youtrack.jetbrains.com/issue/KT-44173).
#### Pointers
Some arguments are passed as pointers and are modified inside the function. For these purposes, just pass mutable
object. If the type is immutable, for example, `String` or `Int`, we have a special wrapper called `Mutable`. Find
examples in the ported sources.#### Remove super classes
* `iIListNode`.
* `TypeAware`.#### Use standard Kotlin classes
Kotlin class|Initial type
---|---
`String`|`_T("String content")`, `L"String content"`, `LPCTSTR`, `iStringTemplate`, `iStringW`, `iStringA`, `iStringT`
`Byte`|`sint8`
`UByte`|`uint8`
`Short`|`sint16`
`UShort`|`uint16`
`Int`|`sint32`
`UInt`|`uint32`
`Long`|`sint64`
`ULong`|`uint64`#### Code folding
IDEs such as IDEA or NetBeans can fold code. It's useful to hide huge pieces of code by default:
```html
//
custom hashCode and equals methods here
//
```## Other links
* Pocket Heroes aka Palm Heroes history — . Has some info
about the game resources compression. Interesting in general ;)
* Group with fans of Palm Kingdoms, the descendant game — .
* Previous repo of this porting effort — — obsolete
and archived.## License
This work is available under Apache 2.0 license.