Skip to content

Commit

Permalink
Merge branch 'release/v0.2.2'
Browse files Browse the repository at this point in the history
  • Loading branch information
Metadorius committed Jul 31, 2021
2 parents 6688975 + db86e56 commit 529ddbd
Show file tree
Hide file tree
Showing 36 changed files with 811 additions and 453 deletions.
9 changes: 6 additions & 3 deletions Phobos.vcxproj
Original file line number Diff line number Diff line change
Expand Up @@ -20,9 +20,13 @@
<ItemGroup>
<ClCompile Include="src\Commands\Commands.cpp" />
<ClCompile Include="src\Commands\Dummy.h" />
<ClCompile Include="src\Ext\Sidebar\Body.cpp" />
<ClCompile Include="src\Ext\Sidebar\Hooks.cpp" />
<ClCompile Include="src\Ext\AnimType\Body.cpp" />
<ClCompile Include="src\Ext\TAction\Body.cpp" />
<ClCompile Include="src\Ext\TAction\Hooks.cpp" />
<ClCompile Include="src\Misc\CaptureManager.cpp" />
<ClCompile Include="src\Misc\TextInput.cpp" />
<ClCompile Include="src\New\Entity\ShieldClass.cpp" />
<ClCompile Include="src\New\Type\RadTypeClass.cpp" />
<ClCompile Include="src\New\Type\ShieldTypeClass.cpp" />
Expand Down Expand Up @@ -88,16 +92,15 @@
<ClInclude Include="src\Commands\NextIdleHarvester.h" />
<ClInclude Include="src\Commands\ObjectInfo.h" />
<ClInclude Include="src\Commands\Commands.h" />
<ClInclude Include="src\Ext\AnimType\Body.h" />
<ClInclude Include="src\Ext\Sidebar\Body.h" />
<ClInclude Include="src\Ext\TAction\Body.h" />
<ClInclude Include="src\Misc\CaptureManager.h" />
<ClInclude Include="src\New\Entity\ShieldClass.h" />
<ClInclude Include="src\New\Type\RadTypeClass.h" />
<ClInclude Include="src\New\Type\ShieldTypeClass.h" />
<ClInclude Include="src\Utilities\Enumerable.h" />
<ClInclude Include="src\ExtraHeaders\CCToolTip.h" />
<ClInclude Include="src\ExtraHeaders\ArmorType.h" />
<ClInclude Include="src\ExtraHeaders\Matrix3D.h" />
<ClInclude Include="src\ExtraHeaders\Themes.h" />
<ClInclude Include="src\Ext\Aircraft\Body.h" />
<ClInclude Include="src\Ext\Building\Body.h" />
<ClInclude Include="src\Ext\BulletType\Body.h" />
Expand Down
6 changes: 3 additions & 3 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -73,7 +73,7 @@ Credits
- **Starkku** - developer

### Contributions
- **Belonit (Gluk-v48)** - project creation, disable empty spawn positions, custom gamemd icon with Command Line, full-color non-paletted PCX, SpySat, BigGap, TransactMoney, PCX Loading Screen, custom DiskLaser radius, extended tooltips, building upgrades enhancement, hide health bar, Sidebar.GDIPosition, help with CellSpread, Blowfish.dll-related errors fix, zero size map previews, semantic locomotor aliases, shields
- **Belonit (Gluk-v48)** - project creation, disable empty spawn positions, custom gamemd icon with Command Line, full-color non-paletted PCX, SpySat, BigGap, TransactMoney, PCX Loading Screen, custom DiskLaser radius, extended tooltips, building upgrades enhancement, hide health bar, Sidebar.GDIPosition, help with CellSpread, Blowfish.dll-related errors fix, zero size map previews, semantic locomotor aliases, shields, input fix
- **Kerbiter (Metadorius)** - SHP debris respect Shadow, building upgrades enhancement, extended tooltips, selection priority filtering, TurretOffset enhancement, customizable ore spawners, select next idle harvester hotkey, interceptor enhancement, zero size map previews, CI/CD, overhauled Unicode font, docs maintenance, VSCode configs, code style
- **tomsons26** - all-around help, assistance and guidance in reverse-engineering, YR binary mappings
- **CCHyper** - all-around help, current project logo, assistance and guidance in reverse-engineering, YR binary mappings
Expand All @@ -83,8 +83,8 @@ Credits
- **SMxReaver** - help with docs, extensive and thorough testing
- **4SG** - help with docs
- **wiktorderelf** - overhauled Unicode font
- **Uranusian (Thrifinesma)** - Mind Control enhancement, custom warhead splash list, harvesters counter, promoted spawns, shields, death after dead fix, customizeable missing cameo, placement mode responding of tab hotkeys fix, overhauled Unicode font, help with docs
- **secsome (SEC-SOME)** - debug info dump hotkey, refactoring & porting of Ares helper code, introducing more Ares-derived stuff, disguise removal warhead, Mind Control removal warhead, Mind Control enhancement, shields, AnimList.PickRandom, MoveToCell fix, unlimited waypoints, Build At trigger action buildup anim fix, Undeploy building into a unit plays `EVA_NewRallyPointEstablished` fix
- **Uranusian (Thrifinesma)** - Mind Control enhancement, custom warhead splash list, harvesters counter, promoted spawns, shields, death after dead fix, customizeable missing cameo, cameo sorting priority, placement mode responding of tab hotkeys fix, producing progress, custom ore gathering anim, NoManualMove, overhauled Unicode font, help with docs
- **secsome (SEC-SOME)** - debug info dump hotkey, refactoring & porting of Ares helper code, introducing more Ares-derived stuff, disguise removal warhead, Mind Control removal warhead, Mind Control enhancement, shields, AnimList.PickRandom, MoveToCell fix, unlimited waypoints, Build At trigger action buildup anim fix, Undeploy building into a unit plays `EVA_NewRallyPointEstablished` fix, custom ore gathering anim
- **Otamaa (Fahroni, BoredEXE)** - help with CellSpread, ported and fixed custom RadType code, togglable ElectricBolt bolts, customizable Chrono Locomotor properties per TechnoClass, DebrisMaximums fixes
- **E1 Elite** - TileSet 255 and above bridge repair fix
- **FS-21** - Dump Object Info enhancements, Powered.KillSpawns, Spawner.LimitRange, ScriptType Actions 71, 72 & 73, MC deployer fixes, help with docs
Expand Down
2 changes: 1 addition & 1 deletion YRpp
12 changes: 12 additions & 0 deletions docs/Fixed-or-Improved-Logics.md
Original file line number Diff line number Diff line change
Expand Up @@ -54,6 +54,18 @@ ChronoDelay= ; integer, delay after teleport for chronosphere

```

### Customizable harvester ore gathering animation

- You can now specify which anim should be drawn when a harvester of specified type is gathering specified type of ore.

In `rulesmd.ini`:
```ini
[SOMETECHNO] ; TechnoType
OreGathering.Anims= ; list of animations
OreGathering.FramesPerDir=15 ; list of integers
OreGathering.Tiberiums=0 ; list of Tiberium IDs
```

### Kill spawns on low power

- `Powered=yes` structures that spawns aircraft like Aircrafts Carriers will stop targeting the enemy if low power.
Expand Down
8 changes: 8 additions & 0 deletions docs/New-or-Enhanced-Logics.md
Original file line number Diff line number Diff line change
Expand Up @@ -139,6 +139,14 @@ BreaksShield=false ; boolean
- `PenetratesShield` allows the warhead ignore the shield and always deal full damage to the TechnoType itself. It also allows targeting the TechnoType as if shield isn't existed.
- `BreaksShield` allows the warhead to always break shields of TechnoTypes, regardless of the amount of strength the shield has remaining or the damage dealt, assuming it affects the shield's armor type. Residual damage, if there is any, still respects `AbsorbOverDamage`.

### No Manual Move

- You can now specify whether a TechnoType is unable to receive move command.

```ini
[SOMETECHNO] ; TechnoType
NoManualMove=no ; boolean
```

## Weapons

Expand Down
35 changes: 35 additions & 0 deletions docs/User-Interface.md
Original file line number Diff line number Diff line change
Expand Up @@ -7,6 +7,10 @@ This page lists all user interface additions, changes, fixes that are implemente
- Enabled ability to load full-color non-paletted PCX graphics of any bitness. This applies to every single PCX file that is loaded, including the Ares-supported PCX files.
- You can specify custom `gamemd.exe` icon via `-icon` command line argument followed by absolute or relative path to an `*.ico` file (f. ex. `gamemd.exe -icon Resources/clienticon.ico`).
- Fixed `Blowfish.dll`-caused error `***FATAL*** String Manager failed to initialize properly`, which occurred if `Blowfish.dll` could not be registered in the OS, for example, it happened when the player did not have administrator rights. With Phobos, if the game did not find a registered file in the system, it will no longer try to register this file, but will load it bypassing registration.
- Fixed non-IME keyboard input to be working correctly for languages / keyboard layouts that use character ranges other than Basic Latin and Latin-1 Supplement (font support required).
```{note}
You can use {download}`the improved vanilla font <_static/files/ImprovedFont-v4.zip>` (v4 and higher) which has way more Unicode character coverage than the default one.
```

## Audio

Expand Down Expand Up @@ -96,6 +100,17 @@ Sidebar.GDIPositions= ; boolean
; no for others
```

### Cameo Sorting

- You can now specify Cameo Priority for any TechnoType/SuperWeaponType. Vanilla sorting rules are [here](https://modenc.renegadeprojects.com/Cameo_Sorting).
- The Cameo Priority is checked just before evevything vanilla. Greater `CameoPriority` wins.

In `rulesmd.ini`:
```ini
[SOMENAME] ; TechnoType/SuperWeaponType
CameoPriority=0 ; integer
```

### Custom Missing Cameo (`XXICON.SHP`)

- You can now specify any SHP/PCX file as XXICON.SHP for missing cameo.
Expand Down Expand Up @@ -143,6 +158,26 @@ Sidebar.HarvesterCounter.ColorRed=255,0,0 ; R,G,B
If you use the vanilla font in your mod, you can use {download}`the improved font <_static/files/ImprovedFont-v4.zip>` (v4 and higher) which among everything already includes the mentioned icons. Otherwise you'd need to draw them yourself using [WWFontEditor](http://nyerguds.arsaneus-design.com/project_stuff/2016/WWFontEditor/release/?C=M;O=D), for example.
```

### Producing Progress

![image](_static/images/producing-progress-01.gif)
*Producing Progress bars in [Fantasy ADVENTURE](https://www.moddb.com/mods/fantasy-adventure)*

- You can now know your factories' status via sidebar!
- You need to draw your own assets (`tab0xpp.shp`, x is replaced by 0-3) and put them into `sidec0x.mix`.

In `uimd.ini`:
```ini
[Sidebar]
ProducingProgress.Show=no ; boolean
```

In `rulesmd.ini`:
```ini
[SOMESIDE] ; Side
Sidebar.ProducingProgress.Offset=0,0 ; X,Y, pixels relative to default
```

## Tooltips

![image](_static/images/tooltips-01.png)
Expand Down
15 changes: 15 additions & 0 deletions docs/Whats-New.md
Original file line number Diff line number Diff line change
Expand Up @@ -33,6 +33,21 @@ In `FAData.ini`:

## Changelog

### 0.2.2

New:
- Customizable producing progress "bars" like CnC:Remastered did (by Uranusian)
- Customizable cameo sorting priority (by Uranusian)
- Customizable harvester ore gathering animation (by secsome, Uranusian)
- Allow making technos unable to be issued with movement order (by Uranusian)

Vanilla fixes:
- Fixed non-IME keyboard input to be working correctly for languages / keyboard layouts that use character ranges other than Basic Latin and Latin-1 Supplement (by Belonit)

Phobos fixes:
- Fixed the critical damage logic not functioning properly (by Uranusian)
- Fixed the bug when executing the stop command game crashes (by Uranusian)

### 0.2.1.1

Phobos fixes:
Expand Down
Binary file added docs/_static/images/producing-progress-01.gif
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
102 changes: 102 additions & 0 deletions src/Ext/AnimType/Body.cpp
Original file line number Diff line number Diff line change
@@ -0,0 +1,102 @@
#include "Body.h"
#include <Phobos.h>
#include <Helpers/Macro.h>
#include <Utilities/TemplateDef.h>
#include <AnimClass.h>
#include <HouseTypeClass.h>
#include <HouseClass.h>
#include <ScenarioClass.h>

template<> const DWORD Extension<AnimTypeClass>::Canary = 0xEEEEEEEE;
AnimTypeExt::ExtContainer AnimTypeExt::ExtMap;

void AnimTypeExt::ExtData::LoadFromINIFile(CCINIClass* pINI)
{
const char* pID = this->OwnerObject()->ID;

INI_EX exINI(pINI);

this->Palette.LoadFromINI(pINI, pID, "CustomPalette");
}

// =============================
// container

AnimTypeExt::ExtContainer::ExtContainer() : Container("AnimTypeClass") { }

AnimTypeExt::ExtContainer::~ExtContainer() = default;

// =============================
// load / save

template <typename T>
void AnimTypeExt::ExtData::Serialize(T & Stm)
{
Stm
.Process(this->Palette);
}

void AnimTypeExt::ExtData::LoadFromStream(PhobosStreamReader & Stm)
{
Extension<AnimTypeClass>::LoadFromStream(Stm);
this->Serialize(Stm);
}

void AnimTypeExt::ExtData::SaveToStream(PhobosStreamWriter & Stm)
{
Extension<AnimTypeClass>::SaveToStream(Stm);
this->Serialize(Stm);
}

// =============================
// container hooks

DEFINE_HOOK(0x42784B, AnimTypeClass_CTOR, 0x5)
{
GET(AnimTypeClass*, pItem, EAX);

AnimTypeExt::ExtMap.FindOrAllocate(pItem);
return 0;
}

DEFINE_HOOK(0x428EA8, AnimTypeClass_SDDTOR, 0x5)
{
GET(AnimTypeClass*, pItem, ECX);

AnimTypeExt::ExtMap.Remove(pItem);
return 0;
}

DEFINE_HOOK_AGAIN(0x428970, AnimTypeClass_SaveLoad_Prefix, 0x8)
DEFINE_HOOK(0x428800, AnimTypeClass_SaveLoad_Prefix, 0xA)
{
GET_STACK(AnimTypeClass*, pItem, 0x4);
GET_STACK(IStream*, pStm, 0x8);

AnimTypeExt::ExtMap.PrepareStream(pItem, pStm);

return 0;
}

DEFINE_HOOK_AGAIN(0x42892C, AnimTypeClass_Load_Suffix, 0x6)
DEFINE_HOOK(0x428958, AnimTypeClass_Load_Suffix, 0x6)
{
AnimTypeExt::ExtMap.LoadStatic();
return 0;
}

DEFINE_HOOK(0x42898A, AnimTypeClass_Save_Suffix, 0x3)
{
AnimTypeExt::ExtMap.SaveStatic();
return 0;
}

DEFINE_HOOK_AGAIN(0x4287E9, AnimTypeClass_LoadFromINI, 0xA)
DEFINE_HOOK(0x4287DC, AnimTypeClass_LoadFromINI, 0xA)
{
GET(AnimTypeClass*, pItem, ESI);
GET_STACK(CCINIClass*, pINI, 0xBC);

AnimTypeExt::ExtMap.LoadFromINI(pItem, pINI);
return 0;
}
48 changes: 48 additions & 0 deletions src/Ext/AnimType/Body.h
Original file line number Diff line number Diff line change
@@ -0,0 +1,48 @@
#pragma once

#include <AnimTypeClass.h>

#include <Utilities/Container.h>
#include <Utilities/Enum.h>
#include <Utilities/Constructs.h>
#include <Utilities/Template.h>

class AnimClass;

class AnimTypeExt
{
public:
using base_type = AnimTypeClass;

class ExtData final : public Extension<AnimTypeClass>
{
public:
CustomPalette Palette;

ExtData(AnimTypeClass* OwnerObject) : Extension<AnimTypeClass>(OwnerObject),
Palette(CustomPalette::PaletteMode::Temperate)
{ }

virtual ~ExtData() = default;

virtual void LoadFromINIFile(CCINIClass* pINI) override;

virtual void InvalidatePointer(void* ptr, bool bRemoved) override { }

virtual void LoadFromStream(PhobosStreamReader& Stm) override;
virtual void SaveToStream(PhobosStreamWriter& Stm) override;

private:
template <typename T>
void Serialize(T& Stm);
};

class ExtContainer final : public Container<AnimTypeExt>
{
public:
ExtContainer();
~ExtContainer();
};

static ExtContainer ExtMap;
};
2 changes: 2 additions & 0 deletions src/Ext/SWType/Body.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -14,6 +14,7 @@ void SWTypeExt::ExtData::Serialize(T& Stm) {
Stm
.Process(this->Money_Amount)
.Process(this->UIDescription)
.Process(this->CameoPriority)
;
}

Expand All @@ -28,6 +29,7 @@ void SWTypeExt::ExtData::LoadFromINIFile(CCINIClass* const pINI) {
INI_EX exINI(pINI);
this->Money_Amount.Read(exINI, pSection, "Money.Amount");
this->UIDescription.Read(exINI, pSection, "UIDescription");
this->CameoPriority.Read(exINI, pSection, "CameoPriority");
}

void SWTypeExt::ExtData::LoadFromStream(PhobosStreamReader& Stm) {
Expand Down
13 changes: 8 additions & 5 deletions src/Ext/SWType/Body.h
Original file line number Diff line number Diff line change
Expand Up @@ -16,16 +16,18 @@ class SWTypeExt

Valueable<int> Money_Amount;
Valueable<CSFText> UIDescription;
Valueable<int> CameoPriority;

ExtData(SuperWeaponTypeClass* OwnerObject) : Extension<SuperWeaponTypeClass>(OwnerObject),
Money_Amount(0),
UIDescription()
ExtData(SuperWeaponTypeClass* OwnerObject) : Extension<SuperWeaponTypeClass>(OwnerObject)
, Money_Amount(0)
, UIDescription()
, CameoPriority(0)
{ }

virtual void LoadFromINIFile(CCINIClass* pINI) override;
virtual ~ExtData() = default;

virtual void InvalidatePointer(void* ptr, bool bRemoved) override {}
virtual void InvalidatePointer(void* ptr, bool bRemoved) override { }

virtual void LoadFromStream(PhobosStreamReader& Stm) override;

Expand All @@ -35,7 +37,8 @@ class SWTypeExt
void Serialize(T& Stm);
};

class ExtContainer final : public Container<SWTypeExt> {
class ExtContainer final : public Container<SWTypeExt>
{
public:
ExtContainer();
~ExtContainer();
Expand Down
4 changes: 3 additions & 1 deletion src/Ext/Side/Body.cpp
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
#include "Body.h"

#include <Themes.h>
#include <ThemeClass.h>

template<> const DWORD Extension<SideClass>::Canary = 0x05B10501;
SideExt::ExtContainer SideExt::ExtMap;
Expand Down Expand Up @@ -29,6 +29,7 @@ void SideExt::ExtData::LoadFromINIFile(CCINIClass* pINI)
this->Sidebar_HarvesterCounter_Offset.Read(exINI, pSection, "Sidebar.HarvesterCounter.Offset");
this->Sidebar_HarvesterCounter_Yellow.Read(exINI, pSection, "Sidebar.HarvesterCounter.ColorYellow");
this->Sidebar_HarvesterCounter_Red.Read(exINI, pSection, "Sidebar.HarvesterCounter.ColorRed");
this->Sidebar_ProducingProgress_Offset.Read(exINI, pSection, "Sidebar.ProducingProgress.Offset");
}

// =============================
Expand All @@ -43,6 +44,7 @@ void SideExt::ExtData::Serialize(T& Stm)
.Process(this->Sidebar_HarvesterCounter_Offset)
.Process(this->Sidebar_HarvesterCounter_Yellow)
.Process(this->Sidebar_HarvesterCounter_Red)
.Process(this->Sidebar_ProducingProgress_Offset)

.Process(this->IngameScore_WinTheme)
.Process(this->IngameScore_LoseTheme)
Expand Down
Loading

0 comments on commit 529ddbd

Please sign in to comment.