You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
42 lines
1.7 KiB
42 lines
1.7 KiB
using UnityEngine;
|
|
|
|
namespace FidelityFX
|
|
{
|
|
/// <summary>
|
|
/// A collection of callbacks required by the FSR2 process.
|
|
/// This allows some customization by the game dev on how to integrate FSR2 into their own game setup.
|
|
/// </summary>
|
|
public class Fsr2Callbacks
|
|
{
|
|
public virtual Shader LoadShader(string name)
|
|
{
|
|
return Resources.Load<Shader>(name);
|
|
}
|
|
|
|
public virtual ComputeShader LoadComputeShader(string name)
|
|
{
|
|
return Resources.Load<ComputeShader>(name);
|
|
}
|
|
|
|
public virtual void UnloadComputeShader(ComputeShader shader)
|
|
{
|
|
Resources.UnloadAsset(shader);
|
|
}
|
|
|
|
/// <summary>
|
|
/// Apply a mipmap bias to in-game textures to prevent them from becoming blurry as the internal rendering resolution lowers.
|
|
/// This will need to be customized on a per-game basis, as there is no clear universal way to determine what are "in-game" textures.
|
|
/// The default implementation will simply apply a mipmap bias to all 2D textures, which will include things like UI textures and which might miss things like terrain texture arrays.
|
|
///
|
|
/// Depending on how your game organizes its assets, you will want to create a filter that more specifically selects the textures that need to have this mipmap bias applied.
|
|
/// You may also want to store the bias offset value and apply it to any assets that are loaded in on demand.
|
|
/// </summary>
|
|
public virtual void ApplyMipmapBias(float biasOffset)
|
|
{
|
|
foreach (var texture in Resources.FindObjectsOfTypeAll<Texture2D>())
|
|
{
|
|
texture.mipMapBias += biasOffset;
|
|
}
|
|
}
|
|
}
|
|
}
|