# D3D11_FILTER Enumeration

Filtering options during texture sampling.

## Syntax

```
typedef enum D3D11_FILTER {
D3D11_FILTER_MIN_MAG_MIP_POINT,
D3D11_FILTER_MIN_MAG_POINT_MIP_LINEAR,
D3D11_FILTER_MIN_POINT_MAG_LINEAR_MIP_POINT,
D3D11_FILTER_MIN_POINT_MAG_MIP_LINEAR,
D3D11_FILTER_MIN_LINEAR_MAG_MIP_POINT,
D3D11_FILTER_MIN_LINEAR_MAG_POINT_MIP_LINEAR,
D3D11_FILTER_MIN_MAG_LINEAR_MIP_POINT,
D3D11_FILTER_MIN_MAG_MIP_LINEAR,
D3D11_FILTER_ANISOTROPIC,
D3D11_FILTER_COMPARISON_MIN_MAG_MIP_POINT,
D3D11_FILTER_COMPARISON_MIN_MAG_POINT_MIP_LINEAR,
D3D11_FILTER_COMPARISON_MIN_POINT_MAG_LINEAR_MIP_POINT,
D3D11_FILTER_COMPARISON_MIN_POINT_MAG_MIP_LINEAR,
D3D11_FILTER_COMPARISON_MIN_LINEAR_MAG_MIP_POINT,
D3D11_FILTER_COMPARISON_MIN_LINEAR_MAG_POINT_MIP_LINEAR,
D3D11_FILTER_COMPARISON_MIN_MAG_LINEAR_MIP_POINT,
D3D11_FILTER_COMPARISON_MIN_MAG_MIP_LINEAR,
D3D11_FILTER_COMPARISON_ANISOTROPIC,
D3D11_FILTER_MINIMUM_MIN_MAG_MIP_POINT,
D3D11_FILTER_MINIMUM_MIN_MAG_POINT_MIP_LINEAR,
D3D11_FILTER_MINIMUM_MIN_POINT_MAG_LINEAR_MIP_POINT,
D3D11_FILTER_MINIMUM_MIN_POINT_MAG_MIP_LINEAR,
D3D11_FILTER_MINIMUM_MIN_LINEAR_MAG_MIP_POINT,
D3D11_FILTER_MINIMUM_MIN_LINEAR_MAG_POINT_MIP_LINEAR,
D3D11_FILTER_MINIMUM_MIN_MAG_LINEAR_MIP_POINT,
D3D11_FILTER_MINIMUM_MIN_MAG_MIP_LINEAR,
D3D11_FILTER_MINIMUM_ANISOTROPIC,
D3D11_FILTER_MAXIMUM_MIN_MAG_MIP_POINT,
D3D11_FILTER_MAXIMUM_MIN_MAG_POINT_MIP_LINEAR,
D3D11_FILTER_MAXIMUM_MIN_POINT_MAG_LINEAR_MIP_POINT,
D3D11_FILTER_MAXIMUM_MIN_POINT_MAG_MIP_LINEAR,
D3D11_FILTER_MAXIMUM_MIN_LINEAR_MAG_MIP_POINT,
D3D11_FILTER_MAXIMUM_MIN_LINEAR_MAG_POINT_MIP_LINEAR,
D3D11_FILTER_MAXIMUM_MIN_MAG_LINEAR_MIP_POINT,
D3D11_FILTER_MAXIMUM_MIN_MAG_MIP_LINEAR,
D3D11_FILTER_MAXIMUM_ANISOTROPIC
} ;
```

## Constants

D3D11_FILTER_MIN_MAG_MIP_POINT | Use point sampling for minification, magnification, and mip-level sampling. |

D3D11_FILTER_MIN_MAG_POINT_MIP_LINEAR | Use point sampling for minification and magnification; use linear interpolation for mip-level sampling. |

D3D11_FILTER_MIN_POINT_MAG_LINEAR_MIP_POINT | Use point sampling for minification; use linear interpolation for magnification; use point sampling for mip-level sampling. |

D3D11_FILTER_MIN_POINT_MAG_MIP_LINEAR | Use point sampling for minification; use linear interpolation for magnification and mip-level sampling. |

D3D11_FILTER_MIN_LINEAR_MAG_MIP_POINT | Use linear interpolation for minification; use point sampling for magnification and mip-level sampling. |

D3D11_FILTER_MIN_LINEAR_MAG_POINT_MIP_LINEAR | Use linear interpolation for minification; use point sampling for magnification; use linear interpolation for mip-level sampling. |

D3D11_FILTER_MIN_MAG_LINEAR_MIP_POINT | Use linear interpolation for minification and magnification; use point sampling for mip-level sampling. |

D3D11_FILTER_MIN_MAG_MIP_LINEAR | Use linear interpolation for minification, magnification, and mip-level sampling. |

D3D11_FILTER_ANISOTROPIC | Use anisotropic interpolation for minification, magnification, and mip-level sampling. |

D3D11_FILTER_COMPARISON_MIN_MAG_MIP_POINT | Use point sampling for minification, magnification, and mip-level sampling. Compare the result to the comparison value. |

D3D11_FILTER_COMPARISON_MIN_MAG_POINT_MIP_LINEAR | Use point sampling for minification and magnification; use linear interpolation for mip-level sampling. Compare the result to the comparison value. |

D3D11_FILTER_COMPARISON_MIN_POINT_MAG_LINEAR_MIP_POINT | Use point sampling for minification; use linear interpolation for magnification; use point sampling for mip-level sampling. Compare the result to the comparison value. |

D3D11_FILTER_COMPARISON_MIN_POINT_MAG_MIP_LINEAR | Use point sampling for minification; use linear interpolation for magnification and mip-level sampling. Compare the result to the comparison value. |

D3D11_FILTER_COMPARISON_MIN_LINEAR_MAG_MIP_POINT | Use linear interpolation for minification; use point sampling for magnification and mip-level sampling. Compare the result to the comparison value. |

D3D11_FILTER_COMPARISON_MIN_LINEAR_MAG_POINT_MIP_LINEAR | Use linear interpolation for minification; use point sampling for magnification; use linear interpolation for mip-level sampling. Compare the result to the comparison value. |

D3D11_FILTER_COMPARISON_MIN_MAG_LINEAR_MIP_POINT | Use linear interpolation for minification and magnification; use point sampling for mip-level sampling. Compare the result to the comparison value. |

D3D11_FILTER_COMPARISON_MIN_MAG_MIP_LINEAR | Use linear interpolation for minification, magnification, and mip-level sampling. Compare the result to the comparison value. |

D3D11_FILTER_COMPARISON_ANISOTROPIC | Use anisotropic interpolation for minification, magnification, and mip-level sampling. Compare the result to the comparison value. |

D3D11_FILTER_MINIMUM_MIN_MAG_MIP_POINT | Fetch the same set of texels as D3D11_FILTER_MIN_MAG_MIP_POINT and instead of filtering them return the minimum of the texels. Texels that are weighted 0 during filtering aren't counted towards the minimum. You can query support for this filter type from the MinMaxFiltering member in the D3D11_FEATURE_DATA_D3D11_OPTIONS1 structure. |

D3D11_FILTER_MINIMUM_MIN_MAG_POINT_MIP_LINEAR | Fetch the same set of texels as D3D11_FILTER_MIN_MAG_POINT_MIP_LINEAR and instead of filtering them return the minimum of the texels. Texels that are weighted 0 during filtering aren't counted towards the minimum. You can query support for this filter type from the MinMaxFiltering member in the D3D11_FEATURE_DATA_D3D11_OPTIONS1 structure. |

D3D11_FILTER_MINIMUM_MIN_POINT_MAG_LINEAR_MIP_POINT | Fetch the same set of texels as D3D11_FILTER_MIN_POINT_MAG_LINEAR_MIP_POINT and instead of filtering them return the minimum of the texels. Texels that are weighted 0 during filtering aren't counted towards the minimum. You can query support for this filter type from the MinMaxFiltering member in the D3D11_FEATURE_DATA_D3D11_OPTIONS1 structure. |

D3D11_FILTER_MINIMUM_MIN_POINT_MAG_MIP_LINEAR | Fetch the same set of texels as D3D11_FILTER_MIN_POINT_MAG_MIP_LINEAR and instead of filtering them return the minimum of the texels. Texels that are weighted 0 during filtering aren't counted towards the minimum. You can query support for this filter type from the MinMaxFiltering member in the D3D11_FEATURE_DATA_D3D11_OPTIONS1 structure. |

D3D11_FILTER_MINIMUM_MIN_LINEAR_MAG_MIP_POINT | Fetch the same set of texels as D3D11_FILTER_MIN_LINEAR_MAG_MIP_POINT and instead of filtering them return the minimum of the texels. Texels that are weighted 0 during filtering aren't counted towards the minimum. You can query support for this filter type from the MinMaxFiltering member in the D3D11_FEATURE_DATA_D3D11_OPTIONS1 structure. |

D3D11_FILTER_MINIMUM_MIN_LINEAR_MAG_POINT_MIP_LINEAR | Fetch the same set of texels as D3D11_FILTER_MIN_LINEAR_MAG_POINT_MIP_LINEAR and instead of filtering them return the minimum of the texels. Texels that are weighted 0 during filtering aren't counted towards the minimum. You can query support for this filter type from the MinMaxFiltering member in the D3D11_FEATURE_DATA_D3D11_OPTIONS1 structure. |

D3D11_FILTER_MINIMUM_MIN_MAG_LINEAR_MIP_POINT | Fetch the same set of texels as D3D11_FILTER_MIN_MAG_LINEAR_MIP_POINT and instead of filtering them return the minimum of the texels. Texels that are weighted 0 during filtering aren't counted towards the minimum. You can query support for this filter type from the MinMaxFiltering member in the D3D11_FEATURE_DATA_D3D11_OPTIONS1 structure. |

D3D11_FILTER_MINIMUM_MIN_MAG_MIP_LINEAR | Fetch the same set of texels as D3D11_FILTER_MIN_MAG_MIP_LINEAR and instead of filtering them return the minimum of the texels. Texels that are weighted 0 during filtering aren't counted towards the minimum. You can query support for this filter type from the MinMaxFiltering member in the D3D11_FEATURE_DATA_D3D11_OPTIONS1 structure. |

D3D11_FILTER_MINIMUM_ANISOTROPIC | Fetch the same set of texels as D3D11_FILTER_ANISOTROPIC and instead of filtering them return the minimum of the texels. Texels that are weighted 0 during filtering aren't counted towards the minimum. You can query support for this filter type from the MinMaxFiltering member in the D3D11_FEATURE_DATA_D3D11_OPTIONS1 structure. |

D3D11_FILTER_MAXIMUM_MIN_MAG_MIP_POINT | Fetch the same set of texels as D3D11_FILTER_MIN_MAG_MIP_POINT and instead of filtering them return the maximum of the texels. Texels that are weighted 0 during filtering aren't counted towards the maximum. You can query support for this filter type from the MinMaxFiltering member in the D3D11_FEATURE_DATA_D3D11_OPTIONS1 structure. |

D3D11_FILTER_MAXIMUM_MIN_MAG_POINT_MIP_LINEAR | Fetch the same set of texels as D3D11_FILTER_MIN_MAG_POINT_MIP_LINEAR and instead of filtering them return the maximum of the texels. Texels that are weighted 0 during filtering aren't counted towards the maximum. You can query support for this filter type from the MinMaxFiltering member in the D3D11_FEATURE_DATA_D3D11_OPTIONS1 structure. |

D3D11_FILTER_MAXIMUM_MIN_POINT_MAG_LINEAR_MIP_POINT | Fetch the same set of texels as D3D11_FILTER_MIN_POINT_MAG_LINEAR_MIP_POINT and instead of filtering them return the maximum of the texels. Texels that are weighted 0 during filtering aren't counted towards the maximum. You can query support for this filter type from the MinMaxFiltering member in the D3D11_FEATURE_DATA_D3D11_OPTIONS1 structure. |

D3D11_FILTER_MAXIMUM_MIN_POINT_MAG_MIP_LINEAR | Fetch the same set of texels as D3D11_FILTER_MIN_POINT_MAG_MIP_LINEAR and instead of filtering them return the maximum of the texels. Texels that are weighted 0 during filtering aren't counted towards the maximum. You can query support for this filter type from the MinMaxFiltering member in the D3D11_FEATURE_DATA_D3D11_OPTIONS1 structure. |

D3D11_FILTER_MAXIMUM_MIN_LINEAR_MAG_MIP_POINT | Fetch the same set of texels as D3D11_FILTER_MIN_LINEAR_MAG_MIP_POINT and instead of filtering them return the maximum of the texels. Texels that are weighted 0 during filtering aren't counted towards the maximum. You can query support for this filter type from the MinMaxFiltering member in the D3D11_FEATURE_DATA_D3D11_OPTIONS1 structure. |

D3D11_FILTER_MAXIMUM_MIN_LINEAR_MAG_POINT_MIP_LINEAR | Fetch the same set of texels as D3D11_FILTER_MIN_LINEAR_MAG_POINT_MIP_LINEAR and instead of filtering them return the maximum of the texels. Texels that are weighted 0 during filtering aren't counted towards the maximum. You can query support for this filter type from the MinMaxFiltering member in the D3D11_FEATURE_DATA_D3D11_OPTIONS1 structure. |

D3D11_FILTER_MAXIMUM_MIN_MAG_LINEAR_MIP_POINT | Fetch the same set of texels as D3D11_FILTER_MIN_MAG_LINEAR_MIP_POINT and instead of filtering them return the maximum of the texels. Texels that are weighted 0 during filtering aren't counted towards the maximum. You can query support for this filter type from the MinMaxFiltering member in the D3D11_FEATURE_DATA_D3D11_OPTIONS1 structure. |

D3D11_FILTER_MAXIMUM_MIN_MAG_MIP_LINEAR | Fetch the same set of texels as D3D11_FILTER_MIN_MAG_MIP_LINEAR and instead of filtering them return the maximum of the texels. Texels that are weighted 0 during filtering aren't counted towards the maximum. You can query support for this filter type from the MinMaxFiltering member in the D3D11_FEATURE_DATA_D3D11_OPTIONS1 structure. |

D3D11_FILTER_MAXIMUM_ANISOTROPIC | Fetch the same set of texels as D3D11_FILTER_ANISOTROPIC and instead of filtering them return the maximum of the texels. Texels that are weighted 0 during filtering aren't counted towards the maximum. You can query support for this filter type from the MinMaxFiltering member in the D3D11_FEATURE_DATA_D3D11_OPTIONS1 structure. |

## Remarks

**Note**If you use different filter types for min versus mag filter, undefined behavior occurs in certain cases where the choice between whether magnification or minification happens is ambiguous. To prevent this undefined behavior, use filter modes that use similar filter operations for both min and mag (or use anisotropic filtering, which avoids the issue as well).

HLSL texture-sampling functions also support comparison filtering during texture sampling. Comparison filtering compares each sampled texel against a comparison value. The boolean result is blended the same way that normal texture filtering is blended.

You can use HLSL intrinsic texture-sampling functions that implement texture filtering only or companion functions that use texture filtering with comparison filtering.

Texture Sampling Function | Texture Sampling Function with Comparison Filtering |
---|---|

sample | samplecmp or samplecmplevelzero |

Comparison filters only work with textures that have the following DXGI formats: R32_FLOAT_X8X24_TYPELESS, R32_FLOAT, R24_UNORM_X8_TYPELESS, R16_UNORM.

## Requirements

Header |
d3d11.h |