Skip to content

Commit

Permalink
Added animations
Browse files Browse the repository at this point in the history
  • Loading branch information
jaygarcia committed Jun 10, 2016
1 parent 6636e49 commit 75384fa
Show file tree
Hide file tree
Showing 2 changed files with 67 additions and 10 deletions.
4 changes: 4 additions & 0 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -87,6 +87,10 @@ style | [style](http://facebook.github.io/react-native/docs/view
trackStyle | [style](http://facebook.github.io/react-native/docs/view.html#style) | Yes | | The style applied to the track
thumbStyle | [style](http://facebook.github.io/react-native/docs/view.html#style) | Yes | | The style applied to the thumb
debugTouchArea | bool | Yes | false | Set this to true to visually see the thumb touch rect in green.
animateTransitions | bool | Yes | false | Set to true if you want to use the default 'spring' animation
animationType | string | Yes | 'spring' | Set to 'spring' or 'timing' to use one of those two types of animations with the default animation properties.
animationConfig | object | Yes | undefined | Used to configure the animation parameters. These are the same parameters in the Animated library.


---

Expand Down
73 changes: 63 additions & 10 deletions src/Slider.js
Original file line number Diff line number Diff line change
Expand Up @@ -9,14 +9,15 @@ import {
Animated,
StyleSheet,
PanResponder,
View
View,
Easing
} from "react-native";

var shallowCompare = require('react-addons-shallow-compare');
var styleEqual = require('style-equal');
const shallowCompare = require('react-addons-shallow-compare'),
styleEqual = require('style-equal');

var TRACK_SIZE = 4;
var THUMB_SIZE = 20;
const TRACK_SIZE = 4,
THUMB_SIZE = 20;

function Rect(x, y, width, height) {
this.x = x;
Expand All @@ -32,6 +33,22 @@ Rect.prototype.containsPoint = function(x, y) {
&& y <= this.y + this.height);
};

const DEFAULT_ANIMATION_CONFIGS = {
spring : {
friction : 7,
tension : 100
},
timing : {
duration : 150,
easing : Easing.inOut(Easing.ease),
delay : 0
},
// decay : { // This has a serious bug
// velocity : 1,
// deceleration : 0.997
// }
};

var Slider = React.createClass({
propTypes: {
/**
Expand Down Expand Up @@ -130,6 +147,21 @@ var Slider = React.createClass({
* Set this to true to visually see the thumb touch rect in green.
*/
debugTouchArea: PropTypes.bool,

/**
* Set to true to animate values with default 'spring' animation type
*/
animateTransitions : PropTypes.bool,

/**
* Custom Animation type. 'spring' or 'timing'.
*/
animationType : PropTypes.oneOf(['spring', 'timing'])

/**
* Used to configure the animation parameters. These are the same parameters in the Animated library.
*/
animationConfig : PropTypes.object
},
getInitialState() {
return {
Expand All @@ -151,6 +183,7 @@ var Slider = React.createClass({
thumbTintColor: '#343434',
thumbTouchSize: {width: 40, height: 40},
debugTouchArea: false,
animationType: 'spring'
};
},
componentWillMount() {
Expand All @@ -165,10 +198,17 @@ var Slider = React.createClass({
});
},
componentWillReceiveProps: function(nextProps) {
var oldValue = this.props.value;
var newValue = nextProps.value;
var props = this.props,
oldValue = props.value,
newValue = nextProps.value;

if (oldValue !== newValue) {
this._setCurrentValue(nextProps.value);
if (props.animateTransitions) {
this._setCurrentValueAnimated(newValue);
}
else {
this._setCurrentValue(newValue);
}
}
},
shouldComponentUpdate: function(nextProps, nextState) {
Expand Down Expand Up @@ -205,7 +245,7 @@ var Slider = React.createClass({
inputRange: [minimumValue, maximumValue],
outputRange: [0, containerSize.width - thumbSize.width],
//extrapolate: 'clamp',
})
});
var valueVisibleStyle = {};
if (!allMeasured) {
valueVisibleStyle.opacity = 0;
Expand All @@ -224,7 +264,7 @@ var Slider = React.createClass({
return (
<View {...other} style={[mainStyles.container, style]} onLayout={this._measureContainer}>
<View
style={[{backgroundColor: maximumTrackTintColor}, mainStyles.track, trackStyle]}
style={[{backgroundColor: maximumTrackTintColor,}, mainStyles.track, trackStyle]}
onLayout={this._measureTrack} />
<Animated.View style={[mainStyles.track, trackStyle, minimumTrackStyle]} />
<Animated.View
Expand Down Expand Up @@ -364,6 +404,19 @@ var Slider = React.createClass({
this.state.value.setValue(value);
},

_setCurrentValueAnimated(value: number) {
var props = this.props,
animationType = props.animationType,
animationConfig = Object.assign(
{},
DEFAULT_ANIMATION_CONFIGS[animationType],
props.animationConfig,
{toValue : value}
);

Animated[animationType](this.state.value, animationConfig).start();
},

_fireChangeEvent(event) {
if (this.props[event]) {
this.props[event](this._getCurrentValue());
Expand Down

0 comments on commit 75384fa

Please sign in to comment.