Skip to content
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

Change ObjectInspector to work via object selection #208

Open
wants to merge 26 commits into
base: master
Choose a base branch
from

Conversation

Givikap120
Copy link
Contributor

@Givikap120 Givikap120 commented Jul 18, 2024

Known issues:

  • Taiko selected objects are appearing as "deselected" when scrolling back earlier than half of the playfield
  • Taiko selected objects are appearing as "deselected" after time it should be hit (even tho Drawable looks like it's still goes to the left)
  • Catch selected objects that were created from nested fruits (slider ends) are fading-in for some reason

First two are most likely because of how pooling in Taiko works
Third is because of some internal catch playfield behavior (didn't found where the fade is applied)

Don't know how to fix the issues, and they're not critical, so waiting on commentary of this situation

@Givikap120 Givikap120 marked this pull request as draft July 18, 2024 23:03
@stanriders
Copy link
Member

  • Do I need to merge STD classes with abstract base as the abstractions isn't used anywhere else?

Yes

  • How can I add selection logic to the CatchSelectableDrawableObject and TaikoSelectableDrawableObject without copying? Or I just need to copy it and that's all?

Copying is fine if can't be moved out easily

  • Do I need to implement selectable spinner (and other objects without respective difficulty hit objects)?

No

  • Selectable object creation can be done with using DrawablePool. But seems to work fine without it. Do I need to do it?

Try running very high object count maps and see how big of a performance hit you get. If it's negligible and your system is more or less average it should be fine I think

@Givikap120 Givikap120 marked this pull request as ready for review July 19, 2024 20:45
@Givikap120
Copy link
Contributor Author

Givikap120 commented Jul 19, 2024

Known issues:

  • Taiko selected objects are appearing as "deselected" when scrolling back earlier than half of the playfield
  • Taiko selected objects are appearing as "deselected" after time it should be hit (even tho Drawable looks like it's still goes to the left)
  • Catch selected objects that were created from nested fruits (slider ends) are fading-in for some reason

First two are most likely because of how pooling in Taiko works
Third is because of some internal catch playfield behavior (didn't found where the fade is applied)

Don't know how to fix the issues, and they're not critical, so waiting on commentary of this situation

It was broken after pooling implemented because the size of the note was updated after the outline was loaded with size assigned
@Givikap120 Givikap120 requested a review from stanriders August 2, 2024 10:52
stanriders and others added 5 commits December 5, 2024 02:40
there are comments that are lying that "potential room for pooling" when pooling is already implemented
@stanriders stanriders added the perfcalc-gui PerformanceCalculatorGUI label Dec 6, 2024
// Copyright (c) ppy Pty Ltd <[email protected]>. Licensed under the MIT Licence.
// See the LICENCE file in the repository root for full licence text.

#nullable enable
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

In general we don't #nullable enable in new files.

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I'm planning to go over the whole project and enabling nullables everywhere after I'm done refactoring this pr

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
perfcalc-gui PerformanceCalculatorGUI
Projects
None yet
Development

Successfully merging this pull request may close these issues.

3 participants