mirror of
				https://github.com/DarkflameUniverse/DarkflameServer.git
				synced 2025-10-25 08:48:12 +00:00 
			
		
		
		
	PhantomPhysics: Fix gravity (#1221)
Fix gravity not being adjusted when colliding with a phantom physics object Tested that while on moonbase, the players gravity is no longer reset to 1 when they change their cheat info.
This commit is contained in:
		| @@ -943,7 +943,7 @@ void GameMessages::SendResurrect(Entity* entity) { | ||||
| 				destroyableComponent->SetImagination(imaginationToRestore); | ||||
| 			} | ||||
| 		} | ||||
| 	}); | ||||
| 		}); | ||||
|  | ||||
|  | ||||
| 	auto cont = static_cast<ControllablePhysicsComponent*>(entity->GetComponent(eReplicaComponentType::CONTROLLABLE_PHYSICS)); | ||||
| @@ -2964,14 +2964,14 @@ void GameMessages::SendSetStunned(LWOOBJID objectId, eStateChangeType stateChang | ||||
| } | ||||
|  | ||||
| void GameMessages::SendSetStunImmunity(LWOOBJID target, eStateChangeType state, const SystemAddress& sysAddr, | ||||
| 		LWOOBJID originator, | ||||
| 		bool bImmuneToStunAttack, | ||||
| 		bool bImmuneToStunEquip, | ||||
| 		bool bImmuneToStunInteract, | ||||
| 		bool bImmuneToStunJump, | ||||
| 		bool bImmuneToStunMove, | ||||
| 		bool bImmuneToStunTurn, | ||||
| 		bool bImmuneToStunUseItem) { | ||||
| 	LWOOBJID originator, | ||||
| 	bool bImmuneToStunAttack, | ||||
| 	bool bImmuneToStunEquip, | ||||
| 	bool bImmuneToStunInteract, | ||||
| 	bool bImmuneToStunJump, | ||||
| 	bool bImmuneToStunMove, | ||||
| 	bool bImmuneToStunTurn, | ||||
| 	bool bImmuneToStunUseItem) { | ||||
| 	CBITSTREAM; | ||||
| 	CMSGHEADER; | ||||
|  | ||||
| @@ -2996,15 +2996,15 @@ void GameMessages::SendSetStunImmunity(LWOOBJID target, eStateChangeType state, | ||||
| } | ||||
|  | ||||
| void GameMessages::SendSetStatusImmunity(LWOOBJID objectId, eStateChangeType state, const SystemAddress& sysAddr, | ||||
| 		bool bImmuneToBasicAttack, | ||||
| 		bool bImmuneToDamageOverTime, | ||||
| 		bool bImmuneToKnockback, | ||||
| 		bool bImmuneToInterrupt, | ||||
| 		bool bImmuneToSpeed, | ||||
| 		bool bImmuneToImaginationGain, | ||||
| 		bool bImmuneToImaginationLoss, | ||||
| 		bool bImmuneToQuickbuildInterrupt, | ||||
| 		bool bImmuneToPullToPoint) { | ||||
| 	bool bImmuneToBasicAttack, | ||||
| 	bool bImmuneToDamageOverTime, | ||||
| 	bool bImmuneToKnockback, | ||||
| 	bool bImmuneToInterrupt, | ||||
| 	bool bImmuneToSpeed, | ||||
| 	bool bImmuneToImaginationGain, | ||||
| 	bool bImmuneToImaginationLoss, | ||||
| 	bool bImmuneToQuickbuildInterrupt, | ||||
| 	bool bImmuneToPullToPoint) { | ||||
| 	CBITSTREAM; | ||||
| 	CMSGHEADER; | ||||
|  | ||||
| @@ -5473,6 +5473,18 @@ void GameMessages::HandleRemoveItemFromInventory(RakNet::BitStream* inStream, En | ||||
| 	} | ||||
| } | ||||
|  | ||||
| void GameMessages::SendSetGravityScale(const LWOOBJID& target, const float effectScale, const SystemAddress& sysAddr) { | ||||
| 	CBITSTREAM; | ||||
| 	CMSGHEADER; | ||||
|  | ||||
| 	bitStream.Write(target); | ||||
| 	bitStream.Write(eGameMessageType::SET_GRAVITY_SCALE); | ||||
|  | ||||
| 	bitStream.Write(effectScale); | ||||
|  | ||||
| 	SEND_PACKET; | ||||
| } | ||||
|  | ||||
| void GameMessages::HandleMoveItemInInventory(RakNet::BitStream* inStream, Entity* entity) { | ||||
| 	bool destInvTypeIsDefault = false; | ||||
| 	int32_t destInvType = eInventoryType::INVALID; | ||||
| @@ -6269,7 +6281,7 @@ void GameMessages::HandleConfirmDonationOnPlayer(RakNet::BitStream* inStream, En | ||||
| 	auto* donationEntity = Game::entityManager->GetEntity(characterComponent->GetCurrentInteracting()); | ||||
| 	if (!donationEntity) return; | ||||
| 	auto* donationVendorComponent = donationEntity->GetComponent<DonationVendorComponent>(); | ||||
| 	if(!donationVendorComponent) return; | ||||
| 	if (!donationVendorComponent) return; | ||||
| 	if (donationVendorComponent->GetActivityID() == 0) { | ||||
| 		Game::logger->Log("GameMessages", "WARNING: Trying to dontate to a vendor with no activity"); | ||||
| 		return; | ||||
| @@ -6279,7 +6291,7 @@ void GameMessages::HandleConfirmDonationOnPlayer(RakNet::BitStream* inStream, En | ||||
| 	auto items = inventory->GetItems(); | ||||
| 	if (!items.empty()) { | ||||
| 		uint32_t count = 0; | ||||
| 		for (auto& [itemID, item] : items){ | ||||
| 		for (auto& [itemID, item] : items) { | ||||
| 			count += item->GetCount(); | ||||
| 			item->RemoveFromInventory(); | ||||
| 		} | ||||
| @@ -6297,7 +6309,7 @@ void GameMessages::HandleCancelDonationOnPlayer(RakNet::BitStream* inStream, Ent | ||||
| 	auto* inventory = inventoryComponent->GetInventory(eInventoryType::DONATION); | ||||
| 	if (!inventory) return; | ||||
| 	auto items = inventory->GetItems(); | ||||
| 	for (auto& [itemID, item] : items){ | ||||
| 	for (auto& [itemID, item] : items) { | ||||
| 		inventoryComponent->MoveItemToInventory(item, eInventoryType::BRICKS, item->GetCount(), false, false, true); | ||||
| 	} | ||||
| 	auto* characterComponent = entity->GetComponent<CharacterComponent>(); | ||||
|   | ||||
| @@ -109,6 +109,8 @@ namespace GameMessages { | ||||
|  | ||||
| 	void SendSetInventorySize(Entity* entity, int invType, int size); | ||||
|  | ||||
| 	void SendSetGravityScale(const LWOOBJID& target, const float effectScale, const SystemAddress& sysAddr); | ||||
|  | ||||
| 	void SendSetEmoteLockState(Entity* entity, bool bLock, int emoteID); | ||||
| 	void SendSetJetPackMode(Entity* entity, bool use, bool bypassChecks = false, bool doHover = false, int effectID = -1, float airspeed = 10, float maxAirspeed = 15, float verticalVelocity = 1, int warningEffectID = -1); | ||||
| 	void SendResurrect(Entity* entity); | ||||
|   | ||||
		Reference in New Issue
	
	Block a user
	 David Markowitz
					David Markowitz