-
Notifications
You must be signed in to change notification settings - Fork 62
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Two concepts for reworking input handling #343
Comments
I personally prefer the first approach, makes implementing Views easier and puts less responsibility on them |
I am not sure whether the Views are suitable for this. I thought about a hierarchy of context classes. If the parent context gets enabled (e.g. menu shows up) all child contexts receive no more input. This is more or less the same as your suggestion but uses a separate class. Then if a view (or any other gameplay component) requires input it would activate its context. Keep in mind that not all views actually listen to user input (e.g. health bar). Furthermore one could store variables in the context, for example the Since my original implementation of the callback system is often not used as intended I would like to propose a change. I would split up In each of the function you could access it's globally declared context and use this information to determine which character has to move etc. Just a suggestion. @\all Please get involved and tell us what you think about it. |
Such Views would just pass all input through. It would be possible to define default behaviors via enums like:
In case of the Health Bar:
Is it easier to update the
I think this is a good idea. Luckily this change would be largely independent of the proposed change. So it should not be easier/harder to implement it with the current system than with the proposed system. |
Okay I'm in favor of your solution because you can avoid the redundancy of defining the view tree twice. I just wonder how you would handle the 3D scene. Somehow put it into a view too or rather create a dummy view which does the input handling for the 3D scene? |
I plan to use a dummy view for the player/camera controls. |
@markusobi I would not call it "dummy view", but rather see the main 3d-scene as an UI-View on it's own: The UI-View which shows the game, if that makes sense. |
@ataulien Should this 3d-Scene View actually draw the world? Should it directly call |
@markusobi not sure about that. It probably could though! It would allow for picture-in-picture and all such fancy things. |
Fancy things like mirrors :-) |
And portals!!! |
I sense a Gothic Portal Gun Mod. :D |
I'm all for portals and mirrors! So, I'm also for this 3d- Scene View- thing :D (is this Option 2, the separate Chain of InputHandler?) |
Well, mirrors, portals and other 3d-stuff is usually handled differently. This should not be the reason to chose any of the two options over the other one. |
To make our Input system more maintainable/extendable I have worked out two concepts, which might help in this regard.
Concept 1: Views handle Input.
InputActions will be handled by Views ONLY. The topmost View on the screen will receive all input. Each View can decide to handle the InputAction and/or consume it independently.
A View can decide to handle+consume only specifiy InputActions and let all others through.
Whether or not a View will consume InputActions will in most cases depend on it's visibility.
I.e. when the Loading Screen is visible no binding shall be fired, except for the console (which is on top of the Loading Screen).
If there is no associated View for a binding, one can add a empty Pseudo-View at the right position in the View-Tree.
i.e. to be able to open the stats screen while the inventory is open, an invisible view can be inserted before the inventory view.
Advantage: Implicit order of InputAction handling/consumption through View draw order.
Disadvantages: bound to View/Vieworder. Visibility of Pseudoviews has to be set somewhere.
Concept 2: Passing Input through a separate Chain of InputHandler.
This Concept is very similar to Concept 1, but in this case we are not using the View-Tree, but a separate chain of InputActing handling objects.
Analog to Concept 1, an InputAction is passed through the Chain, where each object can decide whether to consume and/or handle it.
A draft of how such chain could look like is found here:keyhandling.dot.pdf.
Advantages: Independent of View-Tree.
Goal
The goal behind these concepts is to make it easier to add new input consuming Views without having to add
isViewXYVisible
all over the place (currently all over the place in different InputAction handlers).Feedback is welcome.
The text was updated successfully, but these errors were encountered: