|
|
@ -92,6 +92,7 @@ public class TerrainLodControl extends AbstractControl { |
|
|
|
|
|
|
|
|
|
|
|
protected ExecutorService executor; |
|
|
|
protected ExecutorService executor; |
|
|
|
protected Future<HashMap<String, UpdatedTerrainPatch>> indexer; |
|
|
|
protected Future<HashMap<String, UpdatedTerrainPatch>> indexer; |
|
|
|
|
|
|
|
private boolean forceUpdate = true; |
|
|
|
|
|
|
|
|
|
|
|
public TerrainLodControl() { |
|
|
|
public TerrainLodControl() { |
|
|
|
} |
|
|
|
} |
|
|
@ -175,10 +176,11 @@ public class TerrainLodControl extends AbstractControl { |
|
|
|
lodOffCount = 0; |
|
|
|
lodOffCount = 0; |
|
|
|
|
|
|
|
|
|
|
|
if (lastCameraLocations != null) { |
|
|
|
if (lastCameraLocations != null) { |
|
|
|
if (lastCameraLocationsTheSame(locations) && !lodCalculator.isLodOff()) |
|
|
|
if (!forceUpdate && lastCameraLocationsTheSame(locations) && !lodCalculator.isLodOff()) |
|
|
|
return; // don't update if in same spot
|
|
|
|
return; // don't update if in same spot
|
|
|
|
else |
|
|
|
else |
|
|
|
lastCameraLocations = cloneVectorList(locations); |
|
|
|
lastCameraLocations = cloneVectorList(locations); |
|
|
|
|
|
|
|
forceUpdate = false; |
|
|
|
} |
|
|
|
} |
|
|
|
else { |
|
|
|
else { |
|
|
|
lastCameraLocations = cloneVectorList(locations); |
|
|
|
lastCameraLocations = cloneVectorList(locations); |
|
|
@ -190,10 +192,6 @@ public class TerrainLodControl extends AbstractControl { |
|
|
|
} |
|
|
|
} |
|
|
|
setLodCalcRunning(true); |
|
|
|
setLodCalcRunning(true); |
|
|
|
|
|
|
|
|
|
|
|
//if (getParent() instanceof TerrainQuad) {
|
|
|
|
|
|
|
|
// return; // we just want the root quad to perform this.
|
|
|
|
|
|
|
|
//}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if (executor == null) |
|
|
|
if (executor == null) |
|
|
|
executor = createExecutorService(); |
|
|
|
executor = createExecutorService(); |
|
|
|
|
|
|
|
|
|
|
@ -202,6 +200,14 @@ public class TerrainLodControl extends AbstractControl { |
|
|
|
UpdateLOD updateLodThread = getLodThread(locations, lodCalculator); |
|
|
|
UpdateLOD updateLodThread = getLodThread(locations, lodCalculator); |
|
|
|
indexer = executor.submit(updateLodThread); |
|
|
|
indexer = executor.submit(updateLodThread); |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/** |
|
|
|
|
|
|
|
* Force the LOD to update instantly, does not wait for the camera to move. |
|
|
|
|
|
|
|
* It will reset once it has updated. |
|
|
|
|
|
|
|
*/ |
|
|
|
|
|
|
|
public void forceUpdate() { |
|
|
|
|
|
|
|
this.forceUpdate = true; |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
protected void prepareTerrain() { |
|
|
|
protected void prepareTerrain() { |
|
|
|
TerrainQuad terrain = (TerrainQuad)getSpatial(); |
|
|
|
TerrainQuad terrain = (TerrainQuad)getSpatial(); |
|
|
@ -237,24 +243,8 @@ public class TerrainLodControl extends AbstractControl { |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
/*synchronized (updatePatchesLock) { |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if (updatedPatches == null || updatedPatches.isEmpty()) |
|
|
|
|
|
|
|
return; |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// do the actual geometry update here
|
|
|
|
|
|
|
|
for (UpdatedTerrainPatch utp : updatedPatches.values()) { |
|
|
|
|
|
|
|
utp.updateAll(); |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
updatedPatches = null; |
|
|
|
|
|
|
|
}*/ |
|
|
|
|
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
//public boolean hasPatchesToUpdate() {
|
|
|
|
|
|
|
|
// return updatedPatches != null && !updatedPatches.isEmpty();
|
|
|
|
|
|
|
|
//}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
private boolean lastCameraLocationsTheSame(List<Vector3f> locations) { |
|
|
|
private boolean lastCameraLocationsTheSame(List<Vector3f> locations) { |
|
|
|
boolean theSame = true; |
|
|
|
boolean theSame = true; |
|
|
|
for (Vector3f l : locations) { |
|
|
|
for (Vector3f l : locations) { |
|
|
|