Opened 9 years ago
Closed 9 years ago
#35296 closed defect (bug) (fixed)
Image editor spinner and high CPU usage
Reported by: | afercia | Owned by: | afercia |
---|---|---|---|
Milestone: | 4.5 | Priority: | normal |
Severity: | normal | Version: | 4.4 |
Component: | Media | Keywords: | has-patch |
Focuses: | ui | Cc: |
Description
Similar to other spinner performance-related issues, see #31196, #33311, #33322, and #34951.
In the image editor (both in the Media Library and in the Media Modal), when performing an action a semi-transparent layer appears with a spinner set as background.
While on powerful machines with a modern CPU and a dedicated GPU there's just a barely noticeable CPU usage increment, on older machines the spinner set on a so large area, especially when this area is semi-transparent, can make the CPU usage grow significantly and also get stuck at 100%.
Tested on a very old desktop PC with Windows XP and Firefox 43, the time required for a single image "flip" decreases from minutes to about 2 seconds when removing the spinner.
As a best practice, spinners used as backgrounds should always be set on the smallest possible area. In this specific case there's no need to completely remove the spinner when the action completes because it's already in a <div>
that gets hidden with display: none
.
See in the screenshot below: before the patch the whole image editor area gets continuously re-painted while after the patch it happens only on the 20x20 pixels spinner area.
The proposed patch removes also the semi-transparent layer height calculation made with JavaScript. As far as I see it can be set using just CSS.