mirror of
https://github.com/hajimehoshi/ebiten.git
synced 2025-01-12 03:58:55 +01:00
internal/glfwwin: split GDK part to a new package internal/microsoftgdk
Updates #1162
This commit is contained in:
parent
7f46938ff7
commit
ad380a32f4
@ -9,6 +9,8 @@ import (
|
|||||||
"fmt"
|
"fmt"
|
||||||
"strings"
|
"strings"
|
||||||
"unsafe"
|
"unsafe"
|
||||||
|
|
||||||
|
"github.com/hajimehoshi/ebiten/v2/internal/microsoftgdk"
|
||||||
)
|
)
|
||||||
|
|
||||||
func findPixelFormatAttribValue(attribs []int32, values []int32, attrib int32) int32 {
|
func findPixelFormatAttribValue(attribs []int32, values []int32, attrib int32) int32 {
|
||||||
@ -329,7 +331,7 @@ func destroyContextWGL(window *Window) error {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func initWGL() error {
|
func initWGL() error {
|
||||||
if isXbox() {
|
if microsoftgdk.IsXbox() {
|
||||||
return fmt.Errorf("glfwwin: WGL is not available in Xbox")
|
return fmt.Errorf("glfwwin: WGL is not available in Xbox")
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -10,6 +10,8 @@ import (
|
|||||||
"unsafe"
|
"unsafe"
|
||||||
|
|
||||||
"golang.org/x/sys/windows"
|
"golang.org/x/sys/windows"
|
||||||
|
|
||||||
|
"github.com/hajimehoshi/ebiten/v2/internal/microsoftgdk"
|
||||||
)
|
)
|
||||||
|
|
||||||
func createKeyTables() {
|
func createKeyTables() {
|
||||||
@ -168,7 +170,7 @@ func createHelperWindow() error {
|
|||||||
_ShowWindow(_glfw.win32.helperWindowHandle, _SW_HIDE)
|
_ShowWindow(_glfw.win32.helperWindowHandle, _SW_HIDE)
|
||||||
|
|
||||||
// Register for HID device notifications
|
// Register for HID device notifications
|
||||||
if !isXbox() {
|
if !microsoftgdk.IsXbox() {
|
||||||
_GUID_DEVINTERFACE_HID := windows.GUID{
|
_GUID_DEVINTERFACE_HID := windows.GUID{
|
||||||
Data1: 0x4d1e55b2,
|
Data1: 0x4d1e55b2,
|
||||||
Data2: 0xf16f,
|
Data2: 0xf16f,
|
||||||
@ -238,7 +240,7 @@ func platformInit() error {
|
|||||||
createKeyTables()
|
createKeyTables()
|
||||||
|
|
||||||
if isWindows10CreatorsUpdateOrGreaterWin32() {
|
if isWindows10CreatorsUpdateOrGreaterWin32() {
|
||||||
if !isXbox() {
|
if !microsoftgdk.IsXbox() {
|
||||||
if err := _SetProcessDpiAwarenessContext(_DPI_AWARENESS_CONTEXT_PER_MONITOR_AWARE_V2); err != nil && !errors.Is(err, windows.ERROR_ACCESS_DENIED) {
|
if err := _SetProcessDpiAwarenessContext(_DPI_AWARENESS_CONTEXT_PER_MONITOR_AWARE_V2); err != nil && !errors.Is(err, windows.ERROR_ACCESS_DENIED) {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
@ -258,10 +260,10 @@ func platformInit() error {
|
|||||||
if err := createHelperWindow(); err != nil {
|
if err := createHelperWindow(); err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
if isXbox() {
|
if microsoftgdk.IsXbox() {
|
||||||
// On Xbox, APIs to get monitors are not available.
|
// On Xbox, APIs to get monitors are not available.
|
||||||
// Create a pseudo monitor instance instead.
|
// Create a pseudo monitor instance instead.
|
||||||
w, h := monitorResolution()
|
w, h := microsoftgdk.MonitorResolution()
|
||||||
mode := &VidMode{
|
mode := &VidMode{
|
||||||
Width: w,
|
Width: w,
|
||||||
Height: h,
|
Height: h,
|
||||||
|
@ -10,6 +10,8 @@ import (
|
|||||||
"unsafe"
|
"unsafe"
|
||||||
|
|
||||||
"golang.org/x/sys/windows"
|
"golang.org/x/sys/windows"
|
||||||
|
|
||||||
|
"github.com/hajimehoshi/ebiten/v2/internal/microsoftgdk"
|
||||||
)
|
)
|
||||||
|
|
||||||
func monitorCallback(handle _HMONITOR, dc _HDC, rect *_RECT, monitor *Monitor /* _LPARAM */) uintptr /* _BOOL */ {
|
func monitorCallback(handle _HMONITOR, dc _HDC, rect *_RECT, monitor *Monitor /* _LPARAM */) uintptr /* _BOOL */ {
|
||||||
@ -66,7 +68,7 @@ func createMonitor(adapter *_DISPLAY_DEVICEW, display *_DISPLAY_DEVICEW) (*Monit
|
|||||||
}
|
}
|
||||||
|
|
||||||
func pollMonitorsWin32() error {
|
func pollMonitorsWin32() error {
|
||||||
if isXbox() {
|
if microsoftgdk.IsXbox() {
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -234,7 +236,7 @@ func getMonitorContentScaleWin32(handle _HMONITOR) (xscale, yscale float32, err
|
|||||||
}
|
}
|
||||||
|
|
||||||
func (m *Monitor) platformGetMonitorPos() (xpos, ypos int, ok bool) {
|
func (m *Monitor) platformGetMonitorPos() (xpos, ypos int, ok bool) {
|
||||||
if isXbox() {
|
if microsoftgdk.IsXbox() {
|
||||||
return 0, 0, true
|
return 0, 0, true
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -246,7 +248,7 @@ func (m *Monitor) platformGetMonitorPos() (xpos, ypos int, ok bool) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func (m *Monitor) platformGetMonitorContentScale() (xscale, yscale float32, err error) {
|
func (m *Monitor) platformGetMonitorContentScale() (xscale, yscale float32, err error) {
|
||||||
if isXbox() {
|
if microsoftgdk.IsXbox() {
|
||||||
return 1, 1, nil
|
return 1, 1, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -254,8 +256,8 @@ func (m *Monitor) platformGetMonitorContentScale() (xscale, yscale float32, err
|
|||||||
}
|
}
|
||||||
|
|
||||||
func (m *Monitor) platformGetMonitorWorkarea() (xpos, ypos, width, height int) {
|
func (m *Monitor) platformGetMonitorWorkarea() (xpos, ypos, width, height int) {
|
||||||
if isXbox() {
|
if microsoftgdk.IsXbox() {
|
||||||
w, h := monitorResolution()
|
w, h := microsoftgdk.MonitorResolution()
|
||||||
return 0, 0, w, h
|
return 0, 0, w, h
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -320,7 +322,7 @@ loop:
|
|||||||
}
|
}
|
||||||
|
|
||||||
func (m *Monitor) platformGetVideoMode() *VidMode {
|
func (m *Monitor) platformGetVideoMode() *VidMode {
|
||||||
if isXbox() {
|
if microsoftgdk.IsXbox() {
|
||||||
return m.modes[0]
|
return m.modes[0]
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -13,6 +13,8 @@ import (
|
|||||||
"unsafe"
|
"unsafe"
|
||||||
|
|
||||||
"golang.org/x/sys/windows"
|
"golang.org/x/sys/windows"
|
||||||
|
|
||||||
|
"github.com/hajimehoshi/ebiten/v2/internal/microsoftgdk"
|
||||||
)
|
)
|
||||||
|
|
||||||
func (w *Window) getWindowStyle() uint32 {
|
func (w *Window) getWindowStyle() uint32 {
|
||||||
@ -122,7 +124,7 @@ func createIcon(image *Image, xhot, yhot int, icon bool) (_HICON, error) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func getFullWindowSize(style uint32, exStyle uint32, contentWidth, contentHeight int, dpi uint32) (fullWidth, fullHeight int, err error) {
|
func getFullWindowSize(style uint32, exStyle uint32, contentWidth, contentHeight int, dpi uint32) (fullWidth, fullHeight int, err error) {
|
||||||
if isXbox() {
|
if microsoftgdk.IsXbox() {
|
||||||
return contentWidth, contentHeight, nil
|
return contentWidth, contentHeight, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -718,7 +720,7 @@ func windowProc(hWnd windows.HWND, uMsg uint32, wParam _WPARAM, lParam _LPARAM)
|
|||||||
|
|
||||||
scancode := uint32((_HIWORD(uint32(lParam)) & (_KF_EXTENDED | 0xff)))
|
scancode := uint32((_HIWORD(uint32(lParam)) & (_KF_EXTENDED | 0xff)))
|
||||||
if scancode == 0 {
|
if scancode == 0 {
|
||||||
if isXbox() {
|
if microsoftgdk.IsXbox() {
|
||||||
break
|
break
|
||||||
}
|
}
|
||||||
// NOTE: Some synthetic key messages have a scancode of zero
|
// NOTE: Some synthetic key messages have a scancode of zero
|
||||||
@ -1215,7 +1217,7 @@ func (w *Window) createNativeWindow(wndconfig *wndconfig, fbconfig *fbconfig) er
|
|||||||
|
|
||||||
handleToWindow[w.win32.handle] = w
|
handleToWindow[w.win32.handle] = w
|
||||||
|
|
||||||
if !isXbox() && _IsWindows7OrGreater() {
|
if !microsoftgdk.IsXbox() && _IsWindows7OrGreater() {
|
||||||
if err := _ChangeWindowMessageFilterEx(w.win32.handle, _WM_DROPFILES, _MSGFLT_ALLOW, nil); err != nil {
|
if err := _ChangeWindowMessageFilterEx(w.win32.handle, _WM_DROPFILES, _MSGFLT_ALLOW, nil); err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
@ -1232,7 +1234,7 @@ func (w *Window) createNativeWindow(wndconfig *wndconfig, fbconfig *fbconfig) er
|
|||||||
// Adjust window rect to account for DPI scaling of the window frame and
|
// Adjust window rect to account for DPI scaling of the window frame and
|
||||||
// (if enabled) DPI scaling of the content area
|
// (if enabled) DPI scaling of the content area
|
||||||
// This cannot be done until we know what monitor the window was placed on
|
// This cannot be done until we know what monitor the window was placed on
|
||||||
if !isXbox() && w.monitor == nil {
|
if !microsoftgdk.IsXbox() && w.monitor == nil {
|
||||||
rect := _RECT{
|
rect := _RECT{
|
||||||
left: 0,
|
left: 0,
|
||||||
top: 0,
|
top: 0,
|
||||||
@ -1298,7 +1300,7 @@ func (w *Window) createNativeWindow(wndconfig *wndconfig, fbconfig *fbconfig) er
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if !isXbox() {
|
if !microsoftgdk.IsXbox() {
|
||||||
_DragAcceptFiles(w.win32.handle, true)
|
_DragAcceptFiles(w.win32.handle, true)
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1343,7 +1345,7 @@ func registerWindowClassWin32() error {
|
|||||||
// In the original GLFW implementation, an embedded resource GLFW_ICON is used if possible.
|
// In the original GLFW implementation, an embedded resource GLFW_ICON is used if possible.
|
||||||
// See https://www.glfw.org/docs/3.3/group__window.html
|
// See https://www.glfw.org/docs/3.3/group__window.html
|
||||||
|
|
||||||
if !isXbox() {
|
if !microsoftgdk.IsXbox() {
|
||||||
icon, err := _LoadImageW(0, _IDI_APPLICATION, _IMAGE_ICON, 0, 0, _LR_DEFAULTSIZE|_LR_SHARED)
|
icon, err := _LoadImageW(0, _IDI_APPLICATION, _IMAGE_ICON, 0, 0, _LR_DEFAULTSIZE|_LR_SHARED)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
@ -2129,7 +2131,7 @@ func (c *Cursor) platformCreateCursor(image *Image, xhot, yhot int) error {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func (c *Cursor) platformCreateStandardCursor(shape StandardCursor) error {
|
func (c *Cursor) platformCreateStandardCursor(shape StandardCursor) error {
|
||||||
if isXbox() {
|
if microsoftgdk.IsXbox() {
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -19,12 +19,16 @@ import (
|
|||||||
|
|
||||||
"github.com/hajimehoshi/ebiten/v2/internal/graphics"
|
"github.com/hajimehoshi/ebiten/v2/internal/graphics"
|
||||||
"github.com/hajimehoshi/ebiten/v2/internal/graphicsdriver"
|
"github.com/hajimehoshi/ebiten/v2/internal/graphicsdriver"
|
||||||
|
"github.com/hajimehoshi/ebiten/v2/internal/microsoftgdk"
|
||||||
"github.com/hajimehoshi/ebiten/v2/internal/shaderir"
|
"github.com/hajimehoshi/ebiten/v2/internal/shaderir"
|
||||||
)
|
)
|
||||||
|
|
||||||
var theGraphics Graphics
|
var theGraphics Graphics
|
||||||
|
|
||||||
func Get() *Graphics {
|
func Get() *Graphics {
|
||||||
|
if microsoftgdk.IsXbox() {
|
||||||
|
return nil
|
||||||
|
}
|
||||||
return &theGraphics
|
return &theGraphics
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -15,7 +15,7 @@
|
|||||||
//go:build microsoftgdk
|
//go:build microsoftgdk
|
||||||
// +build microsoftgdk
|
// +build microsoftgdk
|
||||||
|
|
||||||
package glfwwin
|
package microsoftgdk
|
||||||
|
|
||||||
// Unfortunately, some functions like XSystemGetDeviceType is not implemented in a DLL,
|
// Unfortunately, some functions like XSystemGetDeviceType is not implemented in a DLL,
|
||||||
// so LoadLibrary is not available.
|
// so LoadLibrary is not available.
|
||||||
@ -40,12 +40,12 @@ const (
|
|||||||
_XSystemDeviceType_XboxScarlettDevkit = 0x08
|
_XSystemDeviceType_XboxScarlettDevkit = 0x08
|
||||||
)
|
)
|
||||||
|
|
||||||
func isXbox() bool {
|
func IsXbox() bool {
|
||||||
t := C.XSystemGetDeviceType()
|
t := C.XSystemGetDeviceType()
|
||||||
return t != _XSystemDeviceType_Unknown && t != _XSystemDeviceType_Pc
|
return t != _XSystemDeviceType_Unknown && t != _XSystemDeviceType_Pc
|
||||||
}
|
}
|
||||||
|
|
||||||
func monitorResolution() (int, int) {
|
func MonitorResolution() (int, int) {
|
||||||
switch C.XSystemGetDeviceType() {
|
switch C.XSystemGetDeviceType() {
|
||||||
case _XSystemDeviceType_XboxOne, _XSystemDeviceType_XboxOneS:
|
case _XSystemDeviceType_XboxOne, _XSystemDeviceType_XboxOneS:
|
||||||
return 1920, 1080
|
return 1920, 1080
|
@ -12,15 +12,15 @@
|
|||||||
// See the License for the specific language governing permissions and
|
// See the License for the specific language governing permissions and
|
||||||
// limitations under the License.
|
// limitations under the License.
|
||||||
|
|
||||||
//go:build !microsoftgdk
|
//go:build !windows || !microsoftgdk
|
||||||
// +build !microsoftgdk
|
// +build !windows !microsoftgdk
|
||||||
|
|
||||||
package glfwwin
|
package microsoftgdk
|
||||||
|
|
||||||
func isXbox() bool {
|
func IsXbox() bool {
|
||||||
return false
|
return false
|
||||||
}
|
}
|
||||||
|
|
||||||
func monitorResolution() (int, int) {
|
func MonitorResolution() (int, int) {
|
||||||
panic("glfwwin: monitorResolution is not implemented in this environment")
|
panic("microsoftgdk: MonitorResolution is not implemented in this environment")
|
||||||
}
|
}
|
Loading…
Reference in New Issue
Block a user