refactor window creation
This commit is contained in:
		
							parent
							
								
									01e888ad25
								
							
						
					
					
						commit
						4a9d73ef04
					
				
							
								
								
									
										72
									
								
								main.go
								
								
								
								
							
							
						
						
									
										72
									
								
								main.go
								
								
								
								
							| 
						 | 
					@ -12,6 +12,7 @@ import "C"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
import (
 | 
					import (
 | 
				
			||||||
	"encoding/binary"
 | 
						"encoding/binary"
 | 
				
			||||||
 | 
						"errors"
 | 
				
			||||||
	"io"
 | 
						"io"
 | 
				
			||||||
	"os"
 | 
						"os"
 | 
				
			||||||
	"unsafe"
 | 
						"unsafe"
 | 
				
			||||||
| 
						 | 
					@ -19,6 +20,48 @@ import (
 | 
				
			||||||
 | 
					
 | 
				
			||||||
const bufSize uint = 2048
 | 
					const bufSize uint = 2048
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					type milkDropWindow struct {
 | 
				
			||||||
 | 
						window  *sdl.Window
 | 
				
			||||||
 | 
						context sdl.GLContext
 | 
				
			||||||
 | 
						handle  C.projectm_handle
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					func newMilkDropWindow(width, height int32) (*milkDropWindow, error) {
 | 
				
			||||||
 | 
						var m milkDropWindow
 | 
				
			||||||
 | 
						var err error
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						m.window, err = sdl.CreateWindow("milkbucket", sdl.WINDOWPOS_UNDEFINED, sdl.WINDOWPOS_UNDEFINED, width, height, sdl.WINDOW_OPENGL|sdl.WINDOW_RESIZABLE)
 | 
				
			||||||
 | 
						if err != nil {
 | 
				
			||||||
 | 
							return &m, err
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						m.context, err = m.window.GLCreateContext()
 | 
				
			||||||
 | 
						if err != nil {
 | 
				
			||||||
 | 
							return &m, err
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						m.handle = C.projectm_create()
 | 
				
			||||||
 | 
						if m.handle == nil {
 | 
				
			||||||
 | 
							return &m, errors.New("error creating projectM instance")
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						C.projectm_set_window_size(m.handle, C.ulong(width), C.ulong(height))
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						return &m, nil
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					func (m *milkDropWindow) destroy() {
 | 
				
			||||||
 | 
						C.projectm_destroy(m.handle)
 | 
				
			||||||
 | 
						sdl.GLDeleteContext(m.context)
 | 
				
			||||||
 | 
						m.window.Destroy()
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					func (m *milkDropWindow) loadPreset(preset string) {
 | 
				
			||||||
 | 
						cPreset := C.CString("/usr/share/projectM/presets/presets_stock/Zylot - Wisps.milk")
 | 
				
			||||||
 | 
						defer C.free(unsafe.Pointer(cPreset))
 | 
				
			||||||
 | 
						C.projectm_load_preset_file(m.handle, cPreset, false)
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
func render(window *sdl.Window, handle C.projectm_handle) (bool, error) {
 | 
					func render(window *sdl.Window, handle C.projectm_handle) (bool, error) {
 | 
				
			||||||
	var audioData [bufSize]int16
 | 
						var audioData [bufSize]int16
 | 
				
			||||||
 | 
					
 | 
				
			||||||
| 
						 | 
					@ -58,43 +101,24 @@ func handleEvent(event sdl.Event, handle C.projectm_handle) bool {
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
func main() {
 | 
					func main() {
 | 
				
			||||||
	windowWidth := 800
 | 
					 | 
				
			||||||
	windowHeight := 600
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	err := sdl.Init(sdl.INIT_VIDEO)
 | 
						err := sdl.Init(sdl.INIT_VIDEO)
 | 
				
			||||||
	if err != nil {
 | 
						if err != nil {
 | 
				
			||||||
		panic(err)
 | 
							panic(err)
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
	defer sdl.Quit()
 | 
						defer sdl.Quit()
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	window, err := sdl.CreateWindow("milkbucket", sdl.WINDOWPOS_UNDEFINED, sdl.WINDOWPOS_UNDEFINED, int32(windowWidth), int32(windowHeight), sdl.WINDOW_OPENGL|sdl.WINDOW_RESIZABLE)
 | 
						m, err := newMilkDropWindow(800, 600)
 | 
				
			||||||
	if err != nil {
 | 
						if err != nil {
 | 
				
			||||||
		panic(err)
 | 
							panic(err)
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
	defer window.Destroy()
 | 
						defer m.destroy()
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	context, err := window.GLCreateContext()
 | 
						m.loadPreset("/usr/share/projectM/presets/presets_stock/Zylot - Wisps.milk")
 | 
				
			||||||
	if err != nil {
 | 
					 | 
				
			||||||
		panic(err)
 | 
					 | 
				
			||||||
	}
 | 
					 | 
				
			||||||
	defer sdl.GLDeleteContext(context)
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	handle := C.projectm_create()
 | 
					 | 
				
			||||||
	if handle == nil {
 | 
					 | 
				
			||||||
		panic("nil")
 | 
					 | 
				
			||||||
	}
 | 
					 | 
				
			||||||
	defer C.projectm_destroy(handle)
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	C.projectm_set_window_size(handle, C.ulong(windowWidth), C.ulong(windowHeight))
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	preset := C.CString("/usr/share/projectM/presets/presets_stock/Zylot - Wisps.milk")
 | 
					 | 
				
			||||||
	defer C.free(unsafe.Pointer(preset))
 | 
					 | 
				
			||||||
	C.projectm_load_preset_file(handle, preset, false)
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
	running := true
 | 
						running := true
 | 
				
			||||||
	for running {
 | 
						for running {
 | 
				
			||||||
		for event := sdl.PollEvent(); event != nil; event = sdl.PollEvent() {
 | 
							for event := sdl.PollEvent(); event != nil; event = sdl.PollEvent() {
 | 
				
			||||||
			running = handleEvent(event, handle)
 | 
								running = handleEvent(event, m.handle)
 | 
				
			||||||
			if !running {
 | 
								if !running {
 | 
				
			||||||
				break
 | 
									break
 | 
				
			||||||
			}
 | 
								}
 | 
				
			||||||
| 
						 | 
					@ -104,7 +128,7 @@ func main() {
 | 
				
			||||||
			break
 | 
								break
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
		running, err = render(window, handle)
 | 
							running, err = render(m.window, m.handle)
 | 
				
			||||||
		if err != nil {
 | 
							if err != nil {
 | 
				
			||||||
			panic(err)
 | 
								panic(err)
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
		Loading…
	
		Reference in New Issue