@ -88,13 +88,22 @@ namespace DetourNavigator
const SharedNavMeshCacheItem & navMeshCacheItem , const TilePosition & playerTile ,
const SharedNavMeshCacheItem & navMeshCacheItem , const TilePosition & playerTile ,
const std : : map < TilePosition , ChangeType > & changedTiles )
const std : : map < TilePosition , ChangeType > & changedTiles )
{
{
* mPlayerTile . lock ( ) = playerTile ;
bool playerTileChanged = false ;
{
auto locked = mPlayerTile . lock ( ) ;
playerTileChanged = * locked ! = playerTile ;
* locked = playerTile ;
}
if ( changedTiles . empty ( ) )
if ( ! playerTileChanged & & changedTiles . empty ( ) )
return ;
return ;
const std : : lock_guard < std : : mutex > lock ( mMutex ) ;
const std : : lock_guard < std : : mutex > lock ( mMutex ) ;
if ( playerTileChanged )
for ( auto & job : mJobs )
job . mDistanceToPlayer = getManhattanDistance ( job . mChangedTile , playerTile ) ;
for ( const auto & changedTile : changedTiles )
for ( const auto & changedTile : changedTiles )
{
{
if ( mPushed [ agentHalfExtents ] . insert ( changedTile . first ) . second )
if ( mPushed [ agentHalfExtents ] . insert ( changedTile . first ) . second )
@ -112,9 +121,20 @@ namespace DetourNavigator
? mLastUpdates [ job . mAgentHalfExtents ] [ job . mChangedTile ] + mSettings . get ( ) . mMinUpdateInterval
? mLastUpdates [ job . mAgentHalfExtents ] [ job . mChangedTile ] + mSettings . get ( ) . mMinUpdateInterval
: std : : chrono : : steady_clock : : time_point ( ) ;
: std : : chrono : : steady_clock : : time_point ( ) ;
mJobs . push ( std : : move ( job ) ) ;
if ( playerTileChanged )
{
mJobs . push_back ( std : : move ( job ) ) ;
}
else
{
const auto it = std : : upper_bound ( mJobs . begin ( ) , mJobs . end ( ) , job ) ;
mJobs . insert ( it , std : : move ( job ) ) ;
}
}
}
}
}
if ( playerTileChanged )
std : : sort ( mJobs . begin ( ) , mJobs . end ( ) ) ;
Log ( Debug : : Debug ) < < " Posted " < < mJobs . size ( ) < < " navigator jobs " ;
Log ( Debug : : Debug ) < < " Posted " < < mJobs . size ( ) < < " navigator jobs " ;
@ -283,7 +303,7 @@ namespace DetourNavigator
while ( true )
while ( true )
{
{
const auto hasJob = [ & ] {
const auto hasJob = [ & ] {
return ( ! mJobs . empty ( ) & & mJobs . top ( ) . mProcessTime < = std : : chrono : : steady_clock : : now ( ) )
return ( ! mJobs . empty ( ) & & mJobs . front ( ) . mProcessTime < = std : : chrono : : steady_clock : : now ( ) )
| | ! threadQueue . mJobs . empty ( ) ;
| | ! threadQueue . mJobs . empty ( ) ;
} ;
} ;
@ -318,11 +338,11 @@ namespace DetourNavigator
{
{
const auto now = std : : chrono : : steady_clock : : now ( ) ;
const auto now = std : : chrono : : steady_clock : : now ( ) ;
if ( jobs . top ( ) . mProcessTime > now )
if ( jobs . front ( ) . mProcessTime > now )
return { } ;
return { } ;
Job job = jobs . top ( ) ;
Job job = jobs . front ( ) ;
jobs . pop ( ) ;
jobs . pop _front ( ) ;
if ( changeLastUpdate & & job . mChangeType = = ChangeType : : update )
if ( changeLastUpdate & & job . mChangeType = = ChangeType : : update )
mLastUpdates [ job . mAgentHalfExtents ] [ job . mChangedTile ] = now ;
mLastUpdates [ job . mAgentHalfExtents ] [ job . mChangedTile ] = now ;
@ -376,7 +396,7 @@ namespace DetourNavigator
if ( mPushed [ job . mAgentHalfExtents ] . insert ( job . mChangedTile ) . second )
if ( mPushed [ job . mAgentHalfExtents ] . insert ( job . mChangedTile ) . second )
{
{
+ + job . mTryNumber ;
+ + job . mTryNumber ;
mJobs . push ( std : : move ( job ) ) ;
mJobs . push _back ( std : : move ( job ) ) ;
mHasJob . notify_all ( ) ;
mHasJob . notify_all ( ) ;
}
}
}
}
@ -385,7 +405,7 @@ namespace DetourNavigator
{
{
if ( queue . mPushed [ job . mAgentHalfExtents ] . insert ( job . mChangedTile ) . second )
if ( queue . mPushed [ job . mAgentHalfExtents ] . insert ( job . mChangedTile ) . second )
{
{
queue . mJobs . push ( std : : move ( job ) ) ;
queue . mJobs . push _back ( std : : move ( job ) ) ;
mHasJob . notify_all ( ) ;
mHasJob . notify_all ( ) ;
}
}
}
}