graphicsdriver/opengl: Refactoring

This commit is contained in:
Hajime Hoshi 2019-11-20 12:23:45 +09:00
parent 52f6be2639
commit 161771cc99

View File

@ -21,7 +21,6 @@ package opengl
import ( import (
"reflect" "reflect"
"runtime"
"unsafe" "unsafe"
"github.com/hajimehoshi/ebiten/internal/graphics" "github.com/hajimehoshi/ebiten/internal/graphics"
@ -32,13 +31,14 @@ const canUsePBO = true
type pboState struct { type pboState struct {
image *Image image *Image
mappedPBO unsafe.Pointer mappedPBO unsafe.Pointer
mapped []byte
} }
var thePBOState pboState var thePBOState pboState
func (s *pboState) mapPBO(img *Image) { func (s *pboState) mapPBO(img *Image) {
if img.pbo == *new(buffer) {
w, h := graphics.InternalImageSize(img.width), graphics.InternalImageSize(img.height) w, h := graphics.InternalImageSize(img.width), graphics.InternalImageSize(img.height)
if img.pbo == *new(buffer) {
img.pbo = img.driver.context.newPixelBufferObject(w, h) img.pbo = img.driver.context.newPixelBufferObject(w, h)
} }
s.image = img s.image = img
@ -47,24 +47,22 @@ func (s *pboState) mapPBO(img *Image) {
if s.mappedPBO == nil { if s.mappedPBO == nil {
panic("opengl: mapPixelBuffer failed") panic("opengl: mapPixelBuffer failed")
} }
}
func (s *pboState) draw(pix []byte, x, y, width, height int) {
w, h := graphics.InternalImageSize(s.image.width), graphics.InternalImageSize(s.image.height)
var mapped []byte var mapped []byte
sh := (*reflect.SliceHeader)(unsafe.Pointer(&mapped)) sh := (*reflect.SliceHeader)(unsafe.Pointer(&mapped))
sh.Data = uintptr(s.mappedPBO) sh.Data = uintptr(s.mappedPBO)
sh.Len = 4 * w * h sh.Len = 4 * w * h
sh.Cap = 4 * w * h sh.Cap = 4 * w * h
s.mapped = mapped
}
func (s *pboState) draw(pix []byte, x, y, width, height int) {
w := graphics.InternalImageSize(s.image.width)
stride := 4 * w stride := 4 * w
offset := 4 * (y*w + x) offset := 4 * (y*w + x)
for j := 0; j < height; j++ { for j := 0; j < height; j++ {
copy(mapped[offset+stride*j:offset+stride*j+4*width], pix[4*width*j:4*width*(j+1)]) copy(s.mapped[offset+stride*j:offset+stride*j+4*width], pix[4*width*j:4*width*(j+1)])
} }
runtime.KeepAlive(mapped)
} }
func (s *pboState) unmapPBO() { func (s *pboState) unmapPBO() {
@ -74,4 +72,5 @@ func (s *pboState) unmapPBO() {
s.image = nil s.image = nil
s.mappedPBO = nil s.mappedPBO = nil
s.mapped = nil
} }