mirror of
https://github.com/baldurk/renderdoc.git
synced 2026-05-04 17:10:47 +00:00
83 lines
3.2 KiB
Python
83 lines
3.2 KiB
Python
import rdtest
|
|
import renderdoc as rd
|
|
|
|
|
|
class VK_Line_Raster(rdtest.TestCase):
|
|
demos_test_name = 'VK_Line_Raster'
|
|
|
|
# Line segments are relative to 100x75 framebuffers. We sample in each corner (adjusted to be sure even with
|
|
# slightly varying rasterization we should sample in the line endpoint) and in the middle
|
|
points = [
|
|
[ 6, 69 ],
|
|
[ 50, 36 ],
|
|
[ 93, 5 ],
|
|
]
|
|
|
|
view = [ 100, 75 ]
|
|
|
|
def sample(self, row, col):
|
|
ret = []
|
|
for p in self.points:
|
|
x = self.view[0] * col + p[0]
|
|
y = self.view[1] * row + p[1]
|
|
|
|
picked: rd.PixelValue = self.controller.PickPixel(self.tex, x, y, rd.Subresource(0, 0, 0), rd.CompType.Typeless)
|
|
ret.append(rdtest.value_compare(picked.floatValue, [0.0, 1.0, 1.0, 1.0]))
|
|
return ret
|
|
|
|
def check_capture(self):
|
|
action = self.find_action("vkCmdEndRenderPass")
|
|
|
|
self.check(action is not None)
|
|
|
|
action = action.previous
|
|
|
|
self.controller.SetFrameEvent(action.eventId, False)
|
|
|
|
pipe: rd.PipeState = self.controller.GetPipelineState()
|
|
|
|
self.tex = pipe.GetOutputTargets()[0].resource
|
|
|
|
texdetails = self.get_texture(self.tex)
|
|
|
|
# Top left we expect a regular line segment.
|
|
s = self.sample(0, 0)
|
|
|
|
# All points should be the line color
|
|
if not rdtest.value_compare(s, [True, True, True]):
|
|
raise rdtest.TestFailureException("Normal line picked values {} doesn't match expectation".format(s))
|
|
|
|
# Next row is unstippled. The lines should either be all present, or not present
|
|
names = ["Rectangle", "Bresenham", "Rectangle Round"]
|
|
for col in [0, 1, 2]:
|
|
s = self.sample(1, col)
|
|
|
|
n = "Unstippled {}".format(names[col])
|
|
|
|
if s[0]:
|
|
if not rdtest.value_compare(s, [True, True, True]):
|
|
raise rdtest.TestFailureException("{} picked values {} doesn't match expectation".format(n, s))
|
|
rdtest.log.success("{} line looks as expected".format(n))
|
|
else:
|
|
if not rdtest.value_compare(s, [False, False, False]):
|
|
raise rdtest.TestFailureException("{} picked values {} doesn't match expectation".format(n, s))
|
|
rdtest.log.success("{} line not supported".format(n))
|
|
|
|
# Final row is stippled. The lines should be present on each end, and not present in the middle
|
|
# (or not present at all)
|
|
for col in [0, 1, 2]:
|
|
s = self.sample(2, col)
|
|
|
|
n = "Stippled {}".format(names[col])
|
|
|
|
if s[0]:
|
|
if not rdtest.value_compare(s, [True, False, True]):
|
|
raise rdtest.TestFailureException("{} picked values {} doesn't match expectation".format(n, s))
|
|
rdtest.log.success("{} line looks as expected".format(n))
|
|
else:
|
|
if not rdtest.value_compare(s, [False, False, False]):
|
|
raise rdtest.TestFailureException("{} picked values {} doesn't match expectation".format(n, s))
|
|
rdtest.log.success("{} line not supported".format(n))
|
|
|
|
rdtest.log.success("All lines look as expected")
|