Skip to content

Commit

Permalink
make noKMOnInput do the thing
Browse files Browse the repository at this point in the history
  • Loading branch information
XuYicong committed May 17, 2023
1 parent 82af019 commit 20c8392
Show file tree
Hide file tree
Showing 3 changed files with 34 additions and 5 deletions.
17 changes: 14 additions & 3 deletions PlayTools/Controls/ControlMode.swift
Original file line number Diff line number Diff line change
Expand Up @@ -14,6 +14,7 @@ public class ControlMode {
public var keyboardMapped = true

public static func trySwap() -> Bool {
// this function is called from `AKPlugin` when `option` is pressed.
if PlayInput.shouldLockCursor {
mode.show(!mode.visible)
return true
Expand All @@ -24,16 +25,24 @@ public class ControlMode {

func setMapping(_ mapped: Bool) {
if mapped {
// `parseKeymap` and `invalidate` roughly do the opposite thing
PlayInput.shared.parseKeymap()
} else {
show(true)
// to avoid infinite recursion
if !visible {
show(true)
}
PlayInput.shared.invalidate()
}
keyboardMapped = mapped
}

func show(_ show: Bool) {
if keyboardMapped {
// special cases where function of `option` should be temparorily disabled.
// if the new auto keymapping feature is enabled, it could cause problems to switch
// cursor show state while typing.
if (!PlaySettings.shared.noKMOnInput && !editor.editorMode)
|| (PlaySettings.shared.noKMOnInput && keyboardMapped) {
if show {
if !visible {
NotificationCenter.default.post(name: NSNotification.Name.playtoolsCursorWillShow,
Expand All @@ -56,7 +65,9 @@ public class ControlMode {
Toucher.writeLog(logMessage: "cursor show switched to \(show)")
visible = show
if !PlaySettings.shared.noKMOnInput {
keyboardMapped = false
// we want to set keymapping as the reverse of curosr show status, not always false.
// as well as do some logic along with it
setMapping(!show)
}
}
}
Expand Down
18 changes: 16 additions & 2 deletions PlayTools/Controls/PlayInput.swift
Original file line number Diff line number Diff line change
Expand Up @@ -16,12 +16,14 @@ class PlayInput {
joystickHandler: [String: (CGFloat, CGFloat) -> Void] = [:]

func invalidate() {
// this is called whenever keymapping disabled, to release all mapping resource
for action in self.actions {
action.invalidate()
}
}

static public func registerButton(key: String, handler: @escaping (Bool) -> Void) {
// this function is called when setting up `button` type of mapping
if "LMB" == key {
PlayInput.shouldLockCursor = true
}
Expand All @@ -34,7 +36,13 @@ class PlayInput {
func parseKeymap() {
actions = [PlayMice.shared]
PlayInput.buttonHandlers.removeAll(keepingCapacity: true)
PlayInput.shouldLockCursor = false
// `shouldLockCursor` is used to disable `option` toggle when there is no mouse mapping
// but in the case this new feature disabled, `option` should always function.
// this variable is initilized here to be checked for mouse mapping later.
// intialize it to the reverse of the new feature's enable state makes
// it always true if the new feature is disabled, as it won't be set false in
// any case anywhere else in this case.
PlayInput.shouldLockCursor = !PlaySettings.shared.noKMOnInput
for button in keymap.keymapData.buttonModels {
actions.append(ButtonAction(data: button))
}
Expand Down Expand Up @@ -65,6 +73,8 @@ class PlayInput {
Toucher.writeLog(logMessage: "editor opened? \(show)")
if show {
self.invalidate()
// there is no special reason to use GC API for editor, instead of NSEvents.
// just voider did this and I'm not changing it yet.
if let keyboard = GCKeyboard.coalesced!.keyboardInput {
keyboard.keyChangedHandler = { _, _, keyCode, pressed in
PlayKeyboard.handleEditorEvent(keyCode: keyCode, pressed: pressed)
Expand Down Expand Up @@ -163,6 +173,9 @@ class PlayKeyboard {
mode.setMapping(false)
Toucher.writeLog(logMessage: "virtual keyboard will show")
}
} else {
// we want to initialize keymapping to false
mode.setMapping(false)
}
AKInterface.shared!.setupKeyboard(keyboard: {keycode, pressed, isRepeat in
if !mode.keyboardMapped {
Expand All @@ -174,7 +187,8 @@ class PlayKeyboard {
}
let mapped = PlayKeyboard.handleEvent(keycode, pressed)
return mapped
},
}, // passing the function to be called when `option` pressed.
// return `true` meaning this key press is consumed, `false` dispatching it to the App
swapMode: ControlMode.trySwap)
}
}
4 changes: 4 additions & 0 deletions PlayTools/Controls/PlayMice.swift
Original file line number Diff line number Diff line change
Expand Up @@ -38,6 +38,7 @@ public class PlayMice: Action {
var fakedMousePressed: Bool {fakedMouseTouchPointId != nil}

public func mouseMovementMapped() -> Bool {
// this is called from `parseKeymap` to set `shouldLockCursor`'s value
for handler in [PlayInput.cameraMoveHandler, PlayInput.joystickHandler]
where handler[PlayMice.elementName] != nil {
return true
Expand Down Expand Up @@ -220,6 +221,9 @@ class CameraAction: Action {

func invalidate() {
PlayInput.cameraMoveHandler.removeValue(forKey: key)
// when noKMOnInput is false, swipe/pan gesture handler would be invalidated when keymapping disabled.
// as it's just a temporary toggle, not fixing it.
// but should remove that toggle as long as new feature considered stable.
PlayInput.cameraScaleHandler[PlayMice.elementName] = nil
swipeMove.invalidate()
swipeScale1.invalidate()
Expand Down

0 comments on commit 20c8392

Please sign in to comment.