-
Notifications
You must be signed in to change notification settings - Fork 3.6k
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
Click drag functionality #200
Comments
Well I did this for unitystation so why not do it again...Taking this on. |
Click-dragging isn't very discover-able. i.e: just remember, we're not limited by SS13's constraints. Things don't have to be click-drags just because they needed to be to circumvent byond lag. |
We could make it more discoverable - and click-dragging is the sensible choice for interactions, like moving stuff that's too big to carry. I agree that it's not so good for buckling or opening other peoples inventory - but pulling a human into a gibber is a natural drag action. The only question is how to make it discoverable. I think highlighting any |
If a click turns into a drag, it'd be nice to have a small icon of whatever you're dragging show up next to the cursor. |
Both of these are good yeah. |
Need some feedback... With current interaction system, we pretty much send every mouse click to the server and leave it up to server to tell us what happens next. For drag and drop interaction, in the presence of lag I worry this leads to an unsmooth experience. For example, with the current "pattern" for interactions, the flow would be like:
The part where client has to wait for server to tell it if a drag can be initiated is what concerns me, coupled with the need for a slight delay before initiating the drag and drop. Does this approach sound okay instead?
My suggested approach means that client will get the drag shadow instantly (assuming they held click for long enough), but it may not immediately see the "candidates" for dropping...even so the client can still go ahead and drop it before they know what are valid candidates if they already have a good knowledge of what can be dropped on. IMO this leads to a more responsive interaction. Does anyone see potential issues with that approach? The issue I can potentially see is the client not knowing if an object is really in a "draggable" state if there are entities which are only draggable in certain situations, but IMO if an entity is ever draggable it should always be draggable, the server will just tell client there's no candidates to drop on. That way it would avoid frustrating "why can't I drag this?", and repeated attempts to get the drag shadow to show up, thinking maybe they didn't hold long enough or click on it precisely. I'm not concerned ATM about conflicting with other kinds of interactions as I already have a pretty good idea how that should work. |
Thinking about it more...I think we don't even need to bother asking the server for possible drop targets...the client should be able to know what the valid drop targets are just looking at visible entities that have particular components or are a certain prototype. |
Sounds like a good design. Making it smooth and client-based is definitely desirable. |
Sounds good to me. |
Not sure if it is the same feature, but inventory click-drag would finally allow to open the backpack/belt by clicking on it, instead of taking it in hands before, and only unequip it with a click drag. |
Running into some limitations with the current binding system because you can't register multiple InputCmdHandlers to a given BoundKeyFunction, and the constructor system already is bound to Use on clientside but I also need to bind to Use for the drag and drop stuff. It's inspiring me to add support for this to the binding system. Right now I think we're kind of lucky that all key functions are only bound by one system / manager. Gonna focus on that first - support for adding multiple bindings to a given key function while being able to explicitly define the order in which the handlers should be resolved. Unless someone thinks that's a really bad idea. I will do that as a separate PR and get a draft up to get someone to take a look at my proposed design before I do the drag and drop changes, otherwise the PR for both will be too big (and I expect I might need to make significant changes to the new binding approach depending on feedback) I think I can come up with a good approach for solving that, but feel free to tell me if I shouldn't even bother with the binding stuff though and just come up with a temporary hack to get the drag and drop + constructor system to work together. |
This reverts commit 0f4ec57.
* Deep Fryer And Its Powers (#163) * Deep Fryer And Its Powers The Deep Fryer has been implemented. It uses Corn Oil, Ghee, and Olive Oil to fry. Other features include: 1. Mixing Oil and Water at a certain temperature causes smoke. 2. When throwing an object at the Deep Fryer, a Chef will *always* land the shot, but anyone else has a chance of missing. 3. When an item is sliced, an event is triggered that other items can see. * Update meal_recipes.yml * Reworking the effects so they won't trigger on init. * Create DeepFryerTest.cs * Commenting out the UnsafeOilVolumeEffects part of the .yml. Something about the sound script inside of it breaks UnintializedSaveTest and it's not necessary for a smoke reaction to occur anyway. * Update DeepFryerSystem.cs (cherry picked from commit f06fc04) * Deep-Fried Crispy Shader (space-wizards#200) (cherry picked from commit b4e2feb) * Adds the jar of olive oil (space-wizards#197) Co-authored-by: Jeff <> (cherry picked from commit ab14a5b) * fried food mods and add missing sounds * flavorol tweaks * ship update --------- Co-authored-by: JJ <47927305+phcodes@users.noreply.github.com> Co-authored-by: Velcroboy <107660393+IamVelcroboy@users.noreply.github.com>
Adding a bit of harmless spice to vending machines
* tweak weather duration and temp a little (cherry picked from commit 65efaa4e844e632f56256b400ed3661f8551ecd3) * add: dynamic weather with it's own temperature (cherry picked from commit ca5bd564ccac0c8a91662eddb9415bf7d1ec8360) * clean up weather systems (space-wizards#28792) * clean up weather systems * Update WeatherComponent.cs * Update SharedWeatherSystem.cs * some fix * Update SharedWeatherSystem.cs * Update WeatherComponent.cs * Update WeatherComponent.cs * revert autoPause * Update SharedWeatherSystem.cs (cherry picked from commit a1e66cf) * fix * Weather fix (space-wizards#30857) * weather fix * localize errors (cherry picked from commit ff412a6) * two extreme weather variants and increase atmos transfer to mobs * remaining commit * fix weather localisation, remove duplicate localisation --------- Co-authored-by: Dan <jamasty@protonmail.com>
Some interactions in SS13 that are behind click drag functionality:
The interaction system needs to support these cases and click drag should be a good way to go about it.
I propose we add an IDroppable interface for components to implement.
When a client's click key is pressed we should store the click's information and permit a small time window before assuming a drag.
We can immediately look up the entity that's being dragged as locations can be different once the timeframe is up.
Once it is established that an interaction is a drag all visible entities should be checked for IDroppable implementations.
Entities that allow the dragged entity to be dropped unto them should be highlighted.
For this, IDroppable should force some method that tests an Entity as well as the actual behavior.
The text was updated successfully, but these errors were encountered: