Skip to content

kingeric1992/enb-smaa

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

14 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

SMAA Enbseries Wrapper

License: MIT

A SMAA 2.8 Wrapper for Dx11 (hlsl) Enbseries 0.288+ by kingeric1992.

Installation

This project can be deployed though following methods:

  • Download and place the project files under the path /enbseries/SMAA
  • git subtree/submodule/clone selected branch into /enbseries/SMAA

Usage

Add #include "SMAA/enbSMAA.fxh" after other enb resources, use existing preset or create new ones and insert SMAA techniques into your technique sections.

    //...
    #include "SMAA/enbSMAA.fxh"
    //...
    technique11 myTechniques3 {...}
    technique11 myTechniques4 SMAA_PASS0(SMAA_Preset_Low)
    technique11 myTechniques5 SMAA_PASS1(SMAA_Preset_Low)
    technique11 myTechniques6 SMAA_PASS2(SMAA_Preset_Low)
    technique11 myTechniques7 {...}

Built-in presets includes SMAA_Preset_Low, SMAA_Preset_Medium, SMAA_Preset_High, SMAA_Preset_Ultra

To use SMAA in first pass

    technique11 myTechniques  SMAA_PASS0_NAME(  SMAA_Preset_Medium, "smaa demo")
    technique11 myTechniques2 SMAA_PASS1(       SMAA_Preset_Medium)
    technique11 myTechniques3 SMAA_PASS2(       SMAA_Preset_Medium)
    technique11 myTechniques4 {...}

To create custom preset, fill-in the SMAA_t struct by creating helper function:

SMAA_t getMyPreset()
{
    SMAA_t o = SMAA_Preset_High; // Starting template
        o.edgeMode           = ; // 0 = ColorEdge, 1 = LumaEdge, 2 = DepthEdge
        o.stage              = ; // 0 = frameBuffer, 1 = edgeTex, 2 = blendWeight, 3 = SMAA

        o.smaa_threshold          = ;
        o.smaa_maxSearchSteps     = ;
        o.smaa_maxSearchStepsDiag = ;
        o.smaa_cornerRounding     = ;
        o.smaa_adaptFactor        = ; // local contrast adaptation factor

        o.pred_enabled       = ; // use predication
        o.pred_threshold     = ;
        o.pred_strength      = ;
        o.pred_scale         = ;
    return o;
}

Or fill in SMAA_t struct directly:

static const SMAA_t myPreset = {
    edgeMode,
    smaa_threshold, smaa_maxSearchSteps, smaa_maxSearchStepDiag,
    smaa_cornerRounding, smaa_adaptFactor,
    pred_enabled,
    pred_threshold, pred_strength, pred_scale,
    stage
}

And use it in the techniques

    technique11 myTechniques3 {...}
    technique11 myTechniques4 SMAA_PASS0(myPreset)
    technique11 myTechniques5 SMAA_PASS1(myPreset)
    technique11 myTechniques6 SMAA_PASS2(myPreset)
    technique11 myTechniques7 {...}
    //...
    technique11 myTechniques12 SMAA_PASS0(getMyPreset())
    technique11 myTechniques13 SMAA_PASS1(getMyPreset())
    technique11 myTechniques14 SMAA_PASS2(getMyPreset())
    technique11 myTechniques15 {...}

The wrapper also provides a helper macro to create UI preset

    SMAA_UI( "UI Prefix ", myUIPreset )

Where the "UI Prefix" is what will be prepend to UI names.

    technique11 myTechniques3 {...}
    technique11 myTechniques4 SMAA_PASS0(myUIPreset)
    technique11 myTechniques5 SMAA_PASS1(myUIPreset)
    technique11 myTechniques6 SMAA_PASS2(myUIPreset)
    technique11 myTechniques7 {...}

in addition, you can change internal rendertarget with :

    #define  SMAA_EDGE_TEX  texture0name   // default is RenderTargetRGB32F (requires 2bit-RGB )
    #define  SMAA_BLEND_TEX texture1name   // default is RenderTargetRGBA64 (RGBA required [0,1] )

prior to including SMAA/enbSMAA.fxh

Acknowledgments

License

License: MIT

This project is using SMAA under MIT LICENSE

About

An smaa wrapper for enbseries

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages