diff options
| author | Giacomo Pozzoni <giacomopoz@gmail.com> | 2020-05-15 18:43:12 +0000 | 
|---|---|---|
| committer | GitHub <noreply@github.com> | 2020-05-15 20:43:12 +0200 | 
| commit | c0b75bf40da8b447a2f3533dabbfad9eba7c6ea1 (patch) | |
| tree | f605937fbcc61b5a97df5e5f76b9caffbd6aada2 /src/server/game/Spells/Spell.cpp | |
| parent | 43b595111dce03258c29fd926201660b9d3acb8d (diff) | |
Core/MMAPs: Adjust walkable climb and fix a lot of mmap raycast issues (#24539)
* Core/MMAPs: Adjust walkable climb
Adjust walkable climb as recast using walkableClimb also to find the poly from a position, giving priority to polys that are below the position but closer than walkableClimb.
* Temporarily disable static collision (the whole check should be removed)
* Core/Spells: removed deprecated mmap path check for TARGET_DEST_CASTER_FRONT_LEAP
* Core/Objects: allow flying units to use the helper as well (flying units casting radius based spells)
* Code refactor
* Handle raycasts that end in a point with no height in the mmap mesh as PATHFIND_NOPATH
* Walk back a bit from raycast hitpoints as sometime the 2D result point is outside of the polygons due to floating point errors.
* Remove whitespace
* Revert 4a197ba22af4eed01be632ea2dd7d103a963f043 as a raycast point path should have the Z retrieved with getPolyHeight(). Raycast will only return a 2-point path with Start and Hitpoint/End
* Cleanup PathGenerator raycast case
* Fix PathGenerator raycast broken if start and end are on same poly.
Fix PathGenerator raycast broken if no wall is hit.
Remove unused case of using raycast with an existing previous path (can be added back properly if needed).
Remove forcing poly length to 2 when we actually have already the right number.
* Use closestPointOnPolyBoundary on the second try of finding a point on poly for raycast.
Note that in this case the mesh height is not used which might cause issues. The poly boundary height will be used instead.
* Handle cases where getPolyHeight() fails because the point is on polygon border (and caused by floating point imprecision)
* Add far from poly flags
* Set PATHFIND_INCOMPLETE in raycast case if startFarFromPoly or endFarFromPoly
* Fix blink close to walls with no valid polygon behind the wall
* Require to re-extract mmaps
Co-authored-by: Ovah <dreadkiller@gmx.de>
Diffstat (limited to 'src/server/game/Spells/Spell.cpp')
| -rw-r--r-- | src/server/game/Spells/Spell.cpp | 18 | 
1 files changed, 2 insertions, 16 deletions
| diff --git a/src/server/game/Spells/Spell.cpp b/src/server/game/Spells/Spell.cpp index 537a5971a32..60e09ef0753 100644 --- a/src/server/game/Spells/Spell.cpp +++ b/src/server/game/Spells/Spell.cpp @@ -1356,21 +1356,7 @@ void Spell::SelectImplicitCasterDestTargets(SpellEffIndex effIndex, SpellImplici              Position pos = dest._position;              unitCaster->MovePositionToFirstCollision(pos, dist, angle); -            // Generate path to that point. -            if (!m_preGeneratedPath) -                m_preGeneratedPath = std::make_unique<PathGenerator>(unitCaster); - -            m_preGeneratedPath->SetPathLengthLimit(dist); - -            // Should we use straightline here ? What do we do when we don't have a full path ? -            bool pathResult = m_preGeneratedPath->CalculatePath(pos.GetPositionX(), pos.GetPositionY(), pos.GetPositionZ(), false, true); -            if (pathResult && m_preGeneratedPath->GetPathType() & (PATHFIND_NORMAL | PATHFIND_SHORTCUT)) -            { -                pos.m_positionX = m_preGeneratedPath->GetActualEndPosition().x; -                pos.m_positionY = m_preGeneratedPath->GetActualEndPosition().y; -                pos.m_positionZ = m_preGeneratedPath->GetActualEndPosition().z; -                dest.Relocate(pos); -            } +            dest.Relocate(pos);              break;          }          default: @@ -5537,7 +5523,7 @@ SpellCastResult Spell::CheckCast(bool strict, uint32* param1 /*= nullptr*/, uint                      m_preGeneratedPath->SetPathLengthLimit(range);                      // first try with raycast, if it fails fall back to normal path -                    bool result = m_preGeneratedPath->CalculatePath(target->GetPositionX(), target->GetPositionY(), target->GetPositionZ(), false, false); +                    bool result = m_preGeneratedPath->CalculatePath(target->GetPositionX(), target->GetPositionY(), target->GetPositionZ(), false);                      if (m_preGeneratedPath->GetPathType() & PATHFIND_SHORT)                          return SPELL_FAILED_NOPATH;                      else if (!result || m_preGeneratedPath->GetPathType() & (PATHFIND_NOPATH | PATHFIND_INCOMPLETE)) | 
