internal/gamepaddb: Bug fix: A mapping for an axis/button might be missing

Closes #1825
This commit is contained in:
Hajime Hoshi 2021-09-25 00:58:03 +09:00
parent 0d673a68ab
commit a0be4a302c

View File

@ -368,9 +368,15 @@ func AxisValue(id string, axis driver.StandardGamepadAxis, state GamepadState) f
if !ok { if !ok {
return 0 return 0
} }
switch m := mappings[axis]; m.Type {
mapping := mappings[axis]
if mapping == nil {
return 0
}
switch mapping.Type {
case mappingTypeAxis: case mappingTypeAxis:
v := state.Axis(m.Index)*float64(m.AxisScale) + float64(m.AxisOffset) v := state.Axis(mapping.Index)*float64(mapping.AxisScale) + float64(mapping.AxisOffset)
if v > 1 { if v > 1 {
return 1 return 1
} else if v < -1 { } else if v < -1 {
@ -378,13 +384,13 @@ func AxisValue(id string, axis driver.StandardGamepadAxis, state GamepadState) f
} }
return v return v
case mappingTypeButton: case mappingTypeButton:
if state.Button(m.Index) { if state.Button(mapping.Index) {
return 1 return 1
} else { } else {
return -1 return -1
} }
case mappingTypeHat: case mappingTypeHat:
if state.Hat(m.Index)&m.HatState != 0 { if state.Hat(mapping.Index)&mapping.HatState != 0 {
return 1 return 1
} else { } else {
return -1 return -1
@ -407,9 +413,14 @@ func buttonValue(id string, button driver.StandardGamepadButton, state GamepadSt
return 0 return 0
} }
switch m := mappings[button]; m.Type { mapping := mappings[button]
if mapping == nil {
return 0
}
switch mapping.Type {
case mappingTypeAxis: case mappingTypeAxis:
v := state.Axis(m.Index)*float64(m.AxisScale) + float64(m.AxisOffset) v := state.Axis(mapping.Index)*float64(mapping.AxisScale) + float64(mapping.AxisOffset)
if v > 1 { if v > 1 {
v = 1 v = 1
} else if v < -1 { } else if v < -1 {
@ -418,12 +429,12 @@ func buttonValue(id string, button driver.StandardGamepadButton, state GamepadSt
// Adjust [-1, 1] to [0, 1] // Adjust [-1, 1] to [0, 1]
return (v + 1) / 2 return (v + 1) / 2
case mappingTypeButton: case mappingTypeButton:
if state.Button(m.Index) { if state.Button(mapping.Index) {
return 1 return 1
} }
return 0 return 0
case mappingTypeHat: case mappingTypeHat:
if state.Hat(m.Index)&m.HatState != 0 { if state.Hat(mapping.Index)&mapping.HatState != 0 {
return 1 return 1
} }
return 0 return 0
@ -444,14 +455,20 @@ func IsButtonPressed(id string, button driver.StandardGamepadButton, state Gamep
if !ok { if !ok {
return false return false
} }
switch m := mappings[button]; m.Type {
mapping := mappings[button]
if mapping == nil {
return false
}
switch mapping.Type {
case mappingTypeAxis: case mappingTypeAxis:
v := buttonValue(id, button, state) v := buttonValue(id, button, state)
return v > threshold return v > threshold
case mappingTypeButton: case mappingTypeButton:
return state.Button(m.Index) return state.Button(mapping.Index)
case mappingTypeHat: case mappingTypeHat:
return state.Hat(m.Index)&m.HatState != 0 return state.Hat(mapping.Index)&mapping.HatState != 0
} }
return false return false