graphicsdriver/metal: Bug fix: avoid using mtl.LoadActionDontCare

Fixes #1019
This commit is contained in:
Hajime Hoshi 2020-02-11 20:28:15 +09:00
parent 38d8cbf6af
commit 9298b044e3

View File

@ -587,13 +587,11 @@ func (d *Driver) Draw(indexLen int, indexOffset int, mode driver.CompositeMode,
d.view.update() d.view.update()
rpd := mtl.RenderPassDescriptor{} rpd := mtl.RenderPassDescriptor{}
if d.dst.screen { // Even though the destination pixels are not used, mtl.LoadActionDontCare might cause glitches
rpd.ColorAttachments[0].LoadAction = mtl.LoadActionDontCare // (#1019). Always using mtl.LoadActionLoad is safe.
rpd.ColorAttachments[0].StoreAction = mtl.StoreActionStore
} else {
rpd.ColorAttachments[0].LoadAction = mtl.LoadActionLoad rpd.ColorAttachments[0].LoadAction = mtl.LoadActionLoad
rpd.ColorAttachments[0].StoreAction = mtl.StoreActionStore rpd.ColorAttachments[0].StoreAction = mtl.StoreActionStore
}
var t mtl.Texture var t mtl.Texture
if d.dst.screen { if d.dst.screen {
if d.screenDrawable == (ca.MetalDrawable{}) { if d.screenDrawable == (ca.MetalDrawable{}) {