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

Adopt reduced motion settings in more places #1760

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

Conversation

nishanthkarthik
Copy link

  1. Refactors theme names to be enums
  2. Disables ripple effect when reduced motion is enabled
  3. Disabled transitions when reduced motion is enabled

};
static Kind kindFromString(QStringView kind);

static QPalette paletteFromTheme(Kind theme);
Copy link
Member

Choose a reason for hiding this comment

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

What's your reason for making this an enum? I planned to allow loading other palettes from files in the future, which is why this is currently still a string. Does this have any benefits apart from reducing a few lines of string duplication?

Copy link
Author

Choose a reason for hiding this comment

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

I added a commit for a custom plasma style that reads off Plasma APIs directly and bypasses the QQC style. As a pre-work, I made it an enum because I wanted warnings about unimplemented switch cases. Unfortunately the results weren't that much better than using the System style. So, I removed the second commit and left the first refactor as-is.

I did not know about the palettes idea - I think we could still emulate sum types with a std::variant compared to using a string. I'll remove this commit if you wish :)

Copy link
Member

Choose a reason for hiding this comment

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

Yeah, I would prefer to only include relevant changes for now.

@@ -335,6 +335,7 @@ Rectangle {
y: messageInput.positionToRectangle(messageInput.completerTriggeredAt).y - height

enter: Transition {
enabled: !Settings.reducedMotion
Copy link
Member

Choose a reason for hiding this comment

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

Originally we were told that fade effects are fine for reducedMotion, which is why we didn't disable those. Do you have a reason to do otherwise?

Copy link
Author

Choose a reason for hiding this comment

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

No, I mechanically disabled all transitions when reducedMotion is enabled. Are there any specific instances where you'd like to keep these? My motivation for disabling transitions is poor performance - on nvidia-wayland, the transitions stutter sometimes on a fairly powerful gpu (1060).

Copy link
Member

Choose a reason for hiding this comment

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

We have the reduced motion setting not because of stutter, we have them to provide a usable experience to people, who get dizzy when stuff on their screen moves. That's why we use fade animations instead. The stutter could probably be easily fixed by figuring out why it stutters, it is very unlikely to be related to your GPU struggling, but probably more because Nheko blocks the UI thread with database work or so.

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

Successfully merging this pull request may close these issues.

2 participants