mirror of
https://github.com/status-im/react-native.git
synced 2025-03-01 09:30:33 +00:00
Fix slider colors in Android
Summary: Hey ! I noticed that the `minimumTrackTintColor` and `maximumTrackTintColor` are exchanged in iOS and Android. In iOS, `minimumTrackTintColor` is the left color and `maximumTrackTintColor` is the right color. In Android, `minimumTrackTintColor` is the right color and `maximumTrackTintColor` is the left color. With this code : ```jsx <Slider style={{ width: 300 }} minimumTrackTintColor="red" maximumTrackTintColor="blue" /> ``` |iOS|Android| |----|----| |data:image/s3,"s3://crabby-images/015cc/015cc630b4141bcea4a3fa09d483cc601285ea2f" alt="image"|data:image/s3,"s3://crabby-images/aae7a/aae7aa5e4336788d8f4df90f69e3d91a9ddfa24b" alt="screenshot_2017-09-21-15-59-59"| |iOS|Android| |----|----| |data:image/s3,"s3://crabby-images/cdf07/cdf07aefeee7d039de8be9a3a5ece927b6883a09" alt="image" (same)|data:image/s3,"s3://crabby-images/439fc/439fcb59f81af5ca0d839b74075e52ed22aac0a6" alt="screenshot_2017-09-21-16-12-04"| Closes https://github.com/facebook/react-native/pull/16053 Differential Revision: D5910299 Pulled By: shergin fbshipit-source-id: 74851e4cc6d54f72ea2755200e26b0d921890b48
This commit is contained in:
parent
979629504b
commit
31904d523d
@ -160,22 +160,22 @@ public class ReactSliderManager extends SimpleViewManager<ReactSlider> {
|
||||
@ReactProp(name = "minimumTrackTintColor", customType = "Color")
|
||||
public void setMinimumTrackTintColor(ReactSlider view, Integer color) {
|
||||
LayerDrawable drawable = (LayerDrawable) view.getProgressDrawable().getCurrent();
|
||||
Drawable background = drawable.findDrawableByLayerId(android.R.id.background);
|
||||
Drawable progress = drawable.findDrawableByLayerId(android.R.id.progress);
|
||||
if (color == null) {
|
||||
background.clearColorFilter();
|
||||
progress.clearColorFilter();
|
||||
} else {
|
||||
background.setColorFilter(color, PorterDuff.Mode.SRC_IN);
|
||||
progress.setColorFilter(color, PorterDuff.Mode.SRC_IN);
|
||||
}
|
||||
}
|
||||
|
||||
@ReactProp(name = "maximumTrackTintColor", customType = "Color")
|
||||
public void setMaximumTrackTintColor(ReactSlider view, Integer color) {
|
||||
LayerDrawable drawable = (LayerDrawable) view.getProgressDrawable().getCurrent();
|
||||
Drawable progress = drawable.findDrawableByLayerId(android.R.id.progress);
|
||||
Drawable background = drawable.findDrawableByLayerId(android.R.id.background);
|
||||
if (color == null) {
|
||||
progress.clearColorFilter();
|
||||
background.clearColorFilter();
|
||||
} else {
|
||||
progress.setColorFilter(color, PorterDuff.Mode.SRC_IN);
|
||||
background.setColorFilter(color, PorterDuff.Mode.SRC_IN);
|
||||
}
|
||||
}
|
||||
|
||||
|
Loading…
x
Reference in New Issue
Block a user