graphicscommand: Adjust texels

This commit is contained in:
Hajime Hoshi 2020-05-30 22:39:39 +09:00
parent 1da6dbcb29
commit eb1b06c326

View File

@ -207,6 +207,11 @@ func fract(x float32) float32 {
return x - float32(math.Floor(float64(x))) return x - float32(math.Floor(float64(x)))
} }
const (
dstAdjustmentFactor = 1.0 / 256.0
texelAdjustmentFactor = 1.0 / 512.0
)
// Flush flushes the command queue. // Flush flushes the command queue.
func (q *commandQueue) Flush() error { func (q *commandQueue) Flush() error {
if len(q.commands) == 0 { if len(q.commands) == 0 {
@ -220,9 +225,6 @@ func (q *commandQueue) Flush() error {
} }
if theGraphicsDriver.HasHighPrecisionFloat() { if theGraphicsDriver.HasHighPrecisionFloat() {
const dstAdjustmentFactor = 1.0 / 256.0
const texelAdjustmentFactor = 1.0 / 512.0
n := q.nvertices / graphics.VertexFloatNum n := q.nvertices / graphics.VertexFloatNum
for i := 0; i < n; i++ { for i := 0; i < n; i++ {
s := q.srcSizes[i] s := q.srcSizes[i]
@ -424,19 +426,29 @@ func (c *drawTrianglesCommand) Exec(indexOffset int) error {
switch v := c.uniforms[i].(type) { switch v := c.uniforms[i].(type) {
case *Image: case *Image:
us[i] = v.image.ID() us[i] = v.image.ID()
if !firstImage { if firstImage {
// Convert pixels to texels. firstImage = false
w, h := v.InternalSize() continue
i++
region := c.uniforms[i].([]float32)
us[i] = []float32{
region[0] / float32(w),
region[1] / float32(h),
region[2] / float32(w),
region[3] / float32(h),
}
} }
firstImage = false
// Convert pixels to texels.
w, h := v.InternalSize()
i++
region := c.uniforms[i].([]float32)
vs := []float32{
region[0] / float32(w),
region[1] / float32(h),
region[2] / float32(w),
region[3] / float32(h),
}
// Adjust regions not to violate neighborhoods (#317, #558, #724).
if theGraphicsDriver.HasHighPrecisionFloat() {
vs[2] -= 1.0 / float32(w) * texelAdjustmentFactor
vs[3] -= 1.0 / float32(h) * texelAdjustmentFactor
}
us[i] = vs
default: default:
us[i] = v us[i] = v
} }