Browse Source

Add flag to disable animations (global and individual components).

pull/214/head
weisj 4 years ago
parent
commit
dfb2a75032
  1. 20
      core/src/main/java/com/github/weisj/darklaf/graphics/Animator.java
  2. 5
      core/src/main/java/com/github/weisj/darklaf/ui/scrollpane/DarkScrollBarListener.java
  3. 10
      core/src/main/java/com/github/weisj/darklaf/ui/togglebutton/DarkToggleButtonListener.java
  4. 2
      core/src/main/resources/com/github/weisj/darklaf/properties/overwrites.properties
  5. 1
      core/src/main/resources/com/github/weisj/darklaf/properties/ui/scrollBar.properties
  6. 1
      core/src/main/resources/com/github/weisj/darklaf/properties/ui/toggleButton.properties

20
core/src/main/java/com/github/weisj/darklaf/graphics/Animator.java

@ -29,8 +29,13 @@ import java.util.concurrent.atomic.AtomicBoolean;
import javax.swing.*; import javax.swing.*;
import com.github.weisj.darklaf.DarkLaf;
import com.github.weisj.darklaf.util.PropertyValue;
/** @author Konstantin Bulenkov */ /** @author Konstantin Bulenkov */
public abstract class Animator { public abstract class Animator {
public static final String ANIMATIONS_FLAG = DarkLaf.SYSTEM_PROPERTY_PREFIX + "animations";
private static final ScheduledExecutorService scheduler = createScheduler(); private static final ScheduledExecutorService scheduler = createScheduler();
private final int totalFrames; private final int totalFrames;
@ -47,6 +52,7 @@ public abstract class Animator {
private int currentFrame; private int currentFrame;
private long startTime; private long startTime;
private long stopTime; private long stopTime;
private boolean enabled = true;
private volatile boolean disposed = false; private volatile boolean disposed = false;
public Animator(final int totalFrames, final int cycleDuration, final int delayFrames) { public Animator(final int totalFrames, final int cycleDuration, final int delayFrames) {
@ -120,11 +126,23 @@ public abstract class Animator {
resume(0); resume(0);
} }
private boolean animationsEnabled() {
return enabled && !PropertyValue.FALSE.equals(System.getProperty(ANIMATIONS_FLAG));
}
public boolean isEnabled() {
return enabled;
}
public void setEnabled(final boolean enabled) {
this.enabled = enabled;
}
public void resume(final int startFrame) { public void resume(final int startFrame) {
if (startFrame < 0) { if (startFrame < 0) {
throw new IllegalArgumentException("Starting frame must be non negative."); throw new IllegalArgumentException("Starting frame must be non negative.");
} }
if (cycleDuration == 0 || startFrame >= totalFrames) { if (cycleDuration == 0 || startFrame >= totalFrames || !animationsEnabled()) {
currentFrame = totalFrames - 1; currentFrame = totalFrames - 1;
paint(); paint();
animationDone(); animationDone();

5
core/src/main/java/com/github/weisj/darklaf/ui/scrollpane/DarkScrollBarListener.java

@ -56,10 +56,15 @@ public class DarkScrollBarListener extends MouseAdapter implements AdjustmentLis
public DarkScrollBarListener(final JScrollBar scrollbar, final DarkScrollBarUI ui) { public DarkScrollBarListener(final JScrollBar scrollbar, final DarkScrollBarUI ui) {
this.scrollbar = scrollbar; this.scrollbar = scrollbar;
this.ui = ui; this.ui = ui;
boolean animationsEnabled = UIManager.getBoolean("ScrollBar.animated");
trackFadeoutAnimator = createTrackFadeoutAnimator(); trackFadeoutAnimator = createTrackFadeoutAnimator();
trackFadeinAnimator = createTrackFadeinAnimator(); trackFadeinAnimator = createTrackFadeinAnimator();
thumbFadeoutAnimator = createThumbFadeoutAnimator(); thumbFadeoutAnimator = createThumbFadeoutAnimator();
thumbFadeinAnimator = createThumbFadeinAnimator(); thumbFadeinAnimator = createThumbFadeinAnimator();
trackFadeoutAnimator.setEnabled(animationsEnabled);
trackFadeinAnimator.setEnabled(animationsEnabled);
thumbFadeoutAnimator.setEnabled(animationsEnabled);
thumbFadeinAnimator.setEnabled(animationsEnabled);
} }
public void uninstall() { public void uninstall() {

10
core/src/main/java/com/github/weisj/darklaf/ui/togglebutton/DarkToggleButtonListener.java

@ -40,7 +40,12 @@ public class DarkToggleButtonListener extends DarkButtonListener<DarkToggleButto
super(b, ui); super(b, ui);
this.selected = b.isSelected(); this.selected = b.isSelected();
button = b; button = b;
animator = new SliderAnimator(b); animator = createAnimator();
animator.setEnabled(UIManager.getBoolean("ToggleButton.animated"));
}
protected SliderAnimator createAnimator() {
return new SliderAnimator(button);
} }
public float getAnimationState() { public float getAnimationState() {
@ -72,13 +77,14 @@ public class DarkToggleButtonListener extends DarkButtonListener<DarkToggleButto
boolean sel = button.isSelected(); boolean sel = button.isSelected();
if (sel != selected) { if (sel != selected) {
selected = sel; selected = sel;
float endState = sel ? 1 : 0;
int startFrame = 0; int startFrame = 0;
if (animator.isRunning()) { if (animator.isRunning()) {
startFrame = animator.getCurrentFrame(); startFrame = animator.getCurrentFrame();
} }
animator.suspend(); animator.suspend();
animator.setForward(sel); animator.setForward(sel);
animator.setEndValue(sel ? 1 : 0); animator.setEndValue(endState);
animator.resume(startFrame); animator.resume(startFrame);
} }
} }

2
core/src/main/resources/com/github/weisj/darklaf/properties/overwrites.properties

@ -33,3 +33,5 @@ Tree.defaultLineStyle = treeLineStyle
Tree.showFullRowInPopup = treeRowPopup Tree.showFullRowInPopup = treeRowPopup
ToolTip.defaultStyle = tooltipStyle ToolTip.defaultStyle = tooltipStyle
TitlePane.unifiedMenuBar = unifiedMenuBar TitlePane.unifiedMenuBar = unifiedMenuBar
ToggleButton.animated = animations
ScrollBar.animated = animations

1
core/src/main/resources/com/github/weisj/darklaf/properties/ui/scrollBar.properties

@ -35,3 +35,4 @@ ScrollBar.thumbHighlight = null
ScrollBar.smallWidth = 8 ScrollBar.smallWidth = 8
ScrollBar.width = 10 ScrollBar.width = 10
ScrollBar.thumbAlpha = 60 ScrollBar.thumbAlpha = 60
ScrollBar.animated = true

1
core/src/main/resources/com/github/weisj/darklaf/properties/ui/toggleButton.properties

@ -40,3 +40,4 @@ ToggleButton.activeFillColor = %textForegroundInactive
ToggleButton.sliderSize = 35,17 ToggleButton.sliderSize = 35,17
ToggleButton.showSliderHints = false ToggleButton.showSliderHints = false
ToggleButton.animated = true

Loading…
Cancel
Save