dongrong7883 2014-08-15 10:54
浏览 64
已采纳

在SDL Go程序中复制纹理时运行时出现紧急情况

I have an SDL2 go program which tries to write a pixel array to the screen. When I try and update the texture with the new pixels the program panics with a runtime error:

fatal error: unexpected signal during runtime execution

Unfortunately I can find little to no documentation about how to pass around unsafe pointers in Go and I'm not sure if I'm approaching this correctly, here is some example code that exhibits the problem:

func main() {
    window := sdl.CreateWindow("test", sdl.WINDOWPOS_UNDEFINED, sdl.WINDOWPOS_UNDEFINED,
        800, 600, sdl.WINDOW_SHOWN)
    renderer := sdl.CreateRenderer(window, -1, 0)
    texture := sdl.CreateTexture(renderer, sdl.PIXELFORMAT_ARGB8888,
        sdl.TEXTUREACCESS_STATIC, 800, 600)

    defer renderer.Destroy()
    defer texture.Destroy()
    defer window.Destroy()

    for {
        pixels := make([]uint32, 800*600)

        texture.Update(nil, unsafe.Pointer(&pixels), int(800*unsafe.Sizeof(pixels)))
        window.UpdateSurface()

        renderer.Clear()
        renderer.Copy(texture, nil, nil)
        renderer.Present()
    }

    sdl.Delay(1000)
    sdl.Quit()
}

This code will compile with no errors, but when ran it will produce a runtime panic, but I can't see what would cause that in this code.

I am using these SDL2 Go bindings: https://github.com/veandco/go-sdl2

  • 写回答

1条回答 默认 最新

  • doudu3961 2014-08-15 12:53
    关注

    The pitch parameter expects the surface's width * sizeof(int32) as far as I can, this code works and prints random pixels every loop:

    func main() {
        window, err := sdl.CreateWindow("test", sdl.WINDOWPOS_UNDEFINED,
            sdl.WINDOWPOS_UNDEFINED, 800, 600, sdl.WINDOW_SHOWN)
        if err != nil {
            log.Fatal(err)
        }
        defer window.Destroy()
    
        renderer, err := sdl.CreateRenderer(window, -1, 0)
        if err != nil {
            log.Fatal(err)
        }
        defer renderer.Destroy()
    
        texture, err := renderer.CreateTexture(sdl.PIXELFORMAT_ARGB8888,
            sdl.TEXTUREACCESS_STATIC, 800, 600)
    
        if err != nil {
            log.Fatal(err)
        }
        defer texture.Destroy()
    
        pixels := make([]uint32, 800*600)
    L:
        for {
            for event := sdl.PollEvent(); event != nil; event = sdl.PollEvent() {
                if _, ok := event.(*sdl.QuitEvent); ok {
                    break L
                }
            }
            for i := range pixels {
                pixels[i] = 0x00777777 + uint32(rand.Intn(0x00AAAAAA))
            }
            //4 == sizeof(int32), unsafe.Sizeof(pixels) returns the actual size of
            //the slice header which is 24
            texture.Update(nil, unsafe.Pointer(&pixels[0]), 800*4)
            window.UpdateSurface()
    
            renderer.Clear()
            renderer.Copy(texture, nil, nil)
            renderer.Present()
        }
    
        sdl.Delay(1000)
        sdl.Quit()
    }
    

    //edit it should be unsafe.Pointer(&pixels[0]) not unsafe.Pointer(&pixels).

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥50 hyper默认的default switch
  • ¥15 网站打不开,提示502 Bad Gateway
  • ¥20 基于MATLAB的绝热压缩空气储能系统代码咨询
  • ¥15 R语言建立随机森林模型出现的问题
  • ¥20 unity内置语言切换的按钮设置
  • ¥15 中级微观经济学,生产可能性边界问题
  • ¥15 TCP传输时不同网卡传输用时差异过大
  • ¥15 请各位看看我写的属于什么算法,或者有更正确的写法?
  • ¥15 html5 qrcode 扫描器
  • ¥15 爬取网页信息并保存需要完整代码