Revision Difference
render.ClearStencilBufferRectangle#512997
<function name="ClearStencilBufferRectangle" parent="render" type="libraryfunc">⤶
<description>⤶
Sets the stencil value in a specified rect.⤶
⤶
This is **not** affected by <page>render.SetStencilWriteMask</page>⤶
</description>⤶
<realm>Client</realm>⤶
<args>⤶
<arg name="originX" type="number">X origin of the rectangle.</arg>⤶
<arg name="originY" type="number">Y origin of the rectangle.</arg>⤶
<arg name="endX" type="number">The end X coordinate of the rectangle.</arg>⤶
<arg name="endY" type="number">The end Y coordinate of the rectangle.</arg>⤶
<arg name="stencilValue" type="number">Value to set cleared stencil buffer to.</arg>⤶
</args>⤶
</function>⤶
⤶
<example>⤶
<description>A basic stencil operation that limits rendering to the centre of the screen</description>⤶
<code>⤶
hook.Add( "PostDrawOpaqueRenderables", "Stencil Tutorial Example", function()⤶
⤶
-- Reset everything to known good⤶
render.SetStencilWriteMask( 0xFF )⤶
render.SetStencilTestMask( 0xFF )⤶
render.SetStencilReferenceValue( 0 )⤶
render.SetStencilCompareFunction( STENCIL_ALWAYS )⤶
render.SetStencilPassOperation( STENCIL_KEEP )⤶
render.SetStencilFailOperation( STENCIL_KEEP )⤶
render.SetStencilZFailOperation( STENCIL_KEEP )⤶
render.ClearStencil()⤶
⤶
-- Enable stencils⤶
render.SetStencilEnable( true )⤶
-- Set the reference value to 1. This is what the compare function tests against⤶
render.SetStencilReferenceValue( 1 )⤶
-- Refuse to write things to the screen unless that pixel's value is 1⤶
render.SetStencilCompareFunction( STENCIL_EQUAL )⤶
-- Write a 1 to the centre third of the screen. Because we cleared it earlier, everything is currently 0⤶
local w, h = ScrW() / 3, ScrH() / 3⤶
local x_start, y_start = w, h⤶
local x_end, y_end = x_start + w, y_start + h⤶
render.ClearStencilBufferRectangle( x_start, y_start, x_end, y_end, 1 )⤶
⤶
-- Draw our entities. They will only draw in the area cleared above⤶
for _, ent in pairs( ents.FindByClass( "sent_stencil_test" ) ) do⤶
ent:DrawModel()⤶
end⤶
⤶
-- Let everything render normally again⤶
render.SetStencilEnable( false )⤶
end )⤶
</code>⤶
<output></output>⤶
⤶
</example>