Actual fix of position declaring bug

This commit is contained in:
iiSaLMaN 2019-08-04 18:27:49 +03:00
parent 9325c024bb
commit 91f35dde58

View File

@ -65,7 +65,7 @@ namespace osu.Game.Screens.Play
/// <returns>Returns the drawable score item of that player.</returns> /// <returns>Returns the drawable score item of that player.</returns>
public InGameScoreItem AddScore(ScoreInfo score, int? initialPosition = null) => score != null ? addScore(score.TotalScore, score.User, initialPosition) : null; public InGameScoreItem AddScore(ScoreInfo score, int? initialPosition = null) => score != null ? addScore(score.TotalScore, score.User, initialPosition) : null;
private int maxPosition => this.Where(i => i.ScorePosition.HasValue).Max(i => i.ScorePosition) ?? 0; private int maxPosition => this.Max(i => this.Any(item => item.InitialPosition.HasValue) ? i.InitialPosition : i.ScorePosition) ?? 0;
private InGameScoreItem addScore(double totalScore, User user = null, int? position = null) private InGameScoreItem addScore(double totalScore, User user = null, int? position = null)
{ {
@ -87,13 +87,11 @@ namespace osu.Game.Screens.Play
private void reorderPositions() private void reorderPositions()
{ {
var orderedByScore = this.OrderByDescending(i => i.TotalScore).ToList(); var orderedByScore = this.OrderByDescending(i => i.TotalScore).ToList();
var orderedPositions = this.OrderByDescending(i => i.ScorePosition.HasValue).ThenBy(i => i.ScorePosition).Select(i => i.ScorePosition).ToList(); var orderedPositions = this.Select(i => this.Any(item => item.InitialPosition.HasValue) ? i.InitialPosition : i.ScorePosition).OrderByDescending(p => p.HasValue).ThenBy(p => p).ToList();
var newDeclaredPosition = maxPosition + 1;
for (int i = 0; i < Count; i++) for (int i = 0; i < Count; i++)
{ {
int newPosition = orderedPositions[i] ?? newDeclaredPosition; int newPosition = orderedPositions[i] ?? maxPosition + 1;
SetLayoutPosition(orderedByScore[i], newPosition); SetLayoutPosition(orderedByScore[i], newPosition);
orderedByScore[i].ScorePosition = DeclareNewPosition ? newPosition : orderedPositions[i]; orderedByScore[i].ScorePosition = DeclareNewPosition ? newPosition : orderedPositions[i];