More aggressive lighting delay, resend neighbour lighting data after chunk generation (#16)

This commit is contained in:
iam 2023-05-28 16:32:44 -04:00 committed by GitHub
parent 5afce81de5
commit 9c6cb1796c
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23

View File

@ -214,24 +214,24 @@ public class LightingChunk extends DynamicChunk {
}
}
if (sendingTask == null) {
sendingTask = MinecraftServer.getSchedulerManager().scheduleTask(() -> {
sendingTask = null;
if (sendingTask != null) sendingTask.cancel();
sendingTask = MinecraftServer.getSchedulerManager().scheduleTask(() -> {
sendingTask = null;
for (LightingChunk f : sendQueue) {
if (f.isLoaded()) {
f.sections.forEach(s -> {
s.blockLight().invalidate();
s.skyLight().invalidate();
});
f.sendLighting();
sendQueue.remove(f);
}
for (LightingChunk f : sendQueue) {
if (f.isLoaded()) {
f.sections.forEach(s -> {
s.blockLight().invalidate();
s.skyLight().invalidate();
});
sendQueue.remove(f);
f.chunkCache.invalidate();
f.lightCache.invalidate();
f.sendLighting();
}
}, TaskSchedule.tick(5), TaskSchedule.stop(), ExecutionType.ASYNC);
}
}
}, TaskSchedule.tick(10), TaskSchedule.stop(), ExecutionType.ASYNC);
}
private static void flushQueue(Instance instance, Set<Point> queue, LightType type) {
@ -338,7 +338,7 @@ public class LightingChunk extends DynamicChunk {
if (c == null) return;
Set<Point> collected = collectRequiredNearby(instance, new Vec(chunkX, sectionY, chunkZ));
// System.out.println("Calculating " + chunkX + " " + sectionY + " " + chunkZ + " | " + collected.size());
// System.out.println("Calculating " + chunkX + " " + sectionY + " " + chunkZ + " | " + collected.size() + " | " + type);
synchronized (instance) {
relight(instance, collected, type);