mirror of
https://mirror.ghproxy.com/https://github.com/dexyfex/CodeWalker
synced 2024-11-29 10:22:53 +08:00
Improved renderable cache invalidating, stops lights etc from flashing when editing
This commit is contained in:
parent
2c8311c936
commit
18285265ca
@ -186,14 +186,14 @@ namespace CodeWalker.Rendering
|
|||||||
|
|
||||||
public void RenderThreadSync()
|
public void RenderThreadSync()
|
||||||
{
|
{
|
||||||
renderables.RenderThreadSync();
|
renderables.RenderThreadSync(currentDevice);
|
||||||
textures.RenderThreadSync();
|
textures.RenderThreadSync(currentDevice);
|
||||||
boundcomps.RenderThreadSync();
|
boundcomps.RenderThreadSync(currentDevice);
|
||||||
instbatches.RenderThreadSync();
|
instbatches.RenderThreadSync(currentDevice);
|
||||||
lodlights.RenderThreadSync();
|
lodlights.RenderThreadSync(currentDevice);
|
||||||
distlodlights.RenderThreadSync();
|
distlodlights.RenderThreadSync(currentDevice);
|
||||||
pathbatches.RenderThreadSync();
|
pathbatches.RenderThreadSync(currentDevice);
|
||||||
waterquads.RenderThreadSync();
|
waterquads.RenderThreadSync(currentDevice);
|
||||||
}
|
}
|
||||||
|
|
||||||
public Renderable GetRenderable(DrawableBase drawable)
|
public Renderable GetRenderable(DrawableBase drawable)
|
||||||
@ -270,7 +270,6 @@ namespace CodeWalker.Rendering
|
|||||||
{
|
{
|
||||||
private ConcurrentQueue<TVal> itemsToLoad = new ConcurrentQueue<TVal>();
|
private ConcurrentQueue<TVal> itemsToLoad = new ConcurrentQueue<TVal>();
|
||||||
private ConcurrentQueue<TVal> itemsToUnload = new ConcurrentQueue<TVal>();
|
private ConcurrentQueue<TVal> itemsToUnload = new ConcurrentQueue<TVal>();
|
||||||
private ConcurrentQueue<TVal> itemsToInvalidate = new ConcurrentQueue<TVal>();
|
|
||||||
private ConcurrentQueue<TKey> keysToInvalidate = new ConcurrentQueue<TKey>();
|
private ConcurrentQueue<TKey> keysToInvalidate = new ConcurrentQueue<TKey>();
|
||||||
private LinkedList<TVal> loadeditems = new LinkedList<TVal>();//only use from content thread!
|
private LinkedList<TVal> loadeditems = new LinkedList<TVal>();//only use from content thread!
|
||||||
private Dictionary<TKey, TVal> cacheitems = new Dictionary<TKey, TVal>();//only use from render thread!
|
private Dictionary<TKey, TVal> cacheitems = new Dictionary<TKey, TVal>();//only use from render thread!
|
||||||
@ -319,7 +318,6 @@ namespace CodeWalker.Rendering
|
|||||||
loadeditems.Clear();
|
loadeditems.Clear();
|
||||||
cacheitems.Clear();
|
cacheitems.Clear();
|
||||||
itemsToUnload = new ConcurrentQueue<TVal>();
|
itemsToUnload = new ConcurrentQueue<TVal>();
|
||||||
itemsToInvalidate = new ConcurrentQueue<TVal>();
|
|
||||||
keysToInvalidate = new ConcurrentQueue<TKey>();
|
keysToInvalidate = new ConcurrentQueue<TKey>();
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -352,18 +350,6 @@ namespace CodeWalker.Rendering
|
|||||||
}
|
}
|
||||||
if (LoadedCount >= maxitemsperloop) break;
|
if (LoadedCount >= maxitemsperloop) break;
|
||||||
}
|
}
|
||||||
while (itemsToInvalidate.TryDequeue(out item))
|
|
||||||
{
|
|
||||||
try
|
|
||||||
{
|
|
||||||
item.Load(device); //invalidated items just need to get reloaded. (they are already unloaded and re-inited)
|
|
||||||
Interlocked.Add(ref CacheUse, item.DataSize);
|
|
||||||
}
|
|
||||||
catch //(Exception ex)
|
|
||||||
{
|
|
||||||
//todo: error handling...
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return LoadedCount;
|
return LoadedCount;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -390,7 +376,7 @@ namespace CodeWalker.Rendering
|
|||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public void RenderThreadSync()
|
public void RenderThreadSync(Device device)
|
||||||
{
|
{
|
||||||
LastFrameTime = DateTime.UtcNow.ToBinary();
|
LastFrameTime = DateTime.UtcNow.ToBinary();
|
||||||
TVal item;
|
TVal item;
|
||||||
@ -399,11 +385,11 @@ namespace CodeWalker.Rendering
|
|||||||
{
|
{
|
||||||
if (cacheitems.TryGetValue(key, out item))
|
if (cacheitems.TryGetValue(key, out item))
|
||||||
{
|
{
|
||||||
|
Interlocked.Add(ref CacheUse, -item.DataSize);
|
||||||
item.Unload();
|
item.Unload();
|
||||||
item.Init(key);
|
item.Init(key);
|
||||||
item.LoadQueued = true;
|
item.Load(device);
|
||||||
itemsToInvalidate.Enqueue(item);
|
Interlocked.Add(ref CacheUse, item.DataSize);
|
||||||
Interlocked.Add(ref CacheUse, -item.DataSize);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
while (itemsToUnload.TryDequeue(out item))
|
while (itemsToUnload.TryDequeue(out item))
|
||||||
|
Loading…
Reference in New Issue
Block a user