2015-10-01 10:23:34 -04:00
# react-native-linear-gradient
2015-03-31 10:44:16 -07:00
2015-03-31 11:42:53 -07:00
A `<LinearGradient>` component for react-native, as seen in
[react-native-login ](https://github.com/brentvatne/react-native-login ).
2016-02-01 17:06:11 +02:00
Version 1.5.0 supports react-native >= 0.19.0
2015-12-07 10:23:30 -08:00
2015-10-01 10:23:34 -04:00
## Add it to your project
2015-03-31 11:42:53 -07:00
2015-12-09 22:14:47 +01:00
You can use [`rnpm` ](https://github.com/rnpm/rnpm ) to add native dependencies automatically:
`$ rnpm link`
or do it manually as described below:
2015-10-01 10:23:34 -04:00
### iOS
2015-09-30 13:06:36 -04:00
2015-03-31 11:42:53 -07:00
1. Run `npm install react-native-linear-gradient --save`
2. Open your project in XCode, right click on `Libraries` and click `Add
2016-01-19 14:38:09 +02:00
Files to "Your Project Name"` Look under ` node_modules/react-native-linear-gradient` and add ` BVLinearGradient.xcodeproj`. [(Screenshot) ](http://url.brentvatne.ca/g9Wp ).
2015-03-31 11:42:53 -07:00
3. Add `libBVLinearGradient.a` to `Build Phases -> Link Binary With Libraries`
[(Screenshot) ](http://url.brentvatne.ca/g9Wp ).
4. Click on `BVLinearGradient.xcodeproj` in `Libraries` and go the `Build
2015-07-20 18:31:23 -07:00
Settings` tab. Double click the text to the right of ` Header Search
2015-07-07 23:48:43 +02:00
Paths` and verify that it has ` $(SRCROOT)/../react-native/React` - if it
2015-03-31 11:42:53 -07:00
isn't, then add it. This is so XCode is able to find the headers that
the `BVLinearGradient` source files are referring to by pointing to the
header files installed within the `react-native` `node_modules`
directory. [(Screenshot) ](http://url.brentvatne.ca/7wE0 ).
5. Whenever you want to use it within React code now you can: `var LinearGradient =
require('react-native-linear-gradient');`
2015-10-16 12:48:26 -05:00
**If you're having trouble, you can point your `package.json` at github to see if the issue has been fixed. Simply change the dependency `"react-native-linear-gradient": "brentvatne/react-native-linear-gradient",` and then `npm install` **
2015-10-16 12:47:11 -05:00
2015-10-01 10:23:34 -04:00
#### Android
1. in `android/settings.gradle`
```
2016-02-01 17:06:11 +02:00
...
include ':react-native-linear-gradient'
project(':react-native-linear-gradient').projectDir = new File(rootProject.projectDir, '../node_modules/react-native-linear-gradient/android')
2015-10-01 10:23:34 -04:00
```
2. in `android/app/build.gradle` add:
```
dependencies {
...
compile project(':react-native-linear-gradient')
}
```
3. and finally, in `android/src/main/java/com/{YOUR_APP_NAME}/MainActivity.java` add:
2016-02-01 17:06:11 +02:00
```java
//...
2015-10-01 10:23:34 -04:00
import com.BV.LinearGradient.LinearGradientPackage; // < --- This !
2016-02-01 17:06:11 +02:00
//...
2015-10-01 10:23:34 -04:00
@Override
2016-02-01 17:06:11 +02:00
protected List< ReactPackage > getPackages() {
return Arrays.< ReactPackage > asList(
new MainReactPackage(),
new LinearGradientPackage() // < ---- and This !
);
}
2015-10-01 10:23:34 -04:00
```
2015-09-30 13:06:36 -04:00
2015-04-06 13:46:12 -07:00
## Examples
2015-03-31 11:42:53 -07:00
2015-04-06 13:49:44 -07:00
### Simple
2015-03-31 11:42:53 -07:00
The following code will produce something like this:
2016-01-19 14:38:09 +02:00
![Example code result ](https://raw.githubusercontent.com/brentvatne/react-native-linear-gradient/master/images/example.png )
2015-03-31 11:42:53 -07:00
```javascript
// Within your render function
< LinearGradient colors = {[' #4c669f ', ' #3b5998 ', ' #192f6a ']} style = {styles.linearGradient} >
< Text style = {styles.buttonText} >
Sign in with Facebook
< / Text >
< / LinearGradient >
// Later on in your styles..
var styles = StyleSheet.create({
linearGradient: {
flex: 1,
paddingLeft: 15,
paddingRight: 15,
borderRadius: 5
},
buttonText: {
fontSize: 18,
fontFamily: 'Gill Sans',
textAlign: 'center',
margin: 10,
color: '#ffffff ',
},
});
```
2015-04-06 13:49:44 -07:00
### Additional props
2015-03-31 17:48:11 -07:00
You can also use start and end points, as well as specify the locations
for the gradient color changes with the `start` , `end` and `locations`
props:
```javascript
< LinearGradient
2015-09-17 03:07:33 -07:00
start={[0.0, 0.25]} end={[0.5, 1.0]}
2015-03-31 17:48:11 -07:00
locations={[0,0.5,0.6]}
colors={['#4c669f ', '#3b5998 ', '#192f6a ']}
style={styles.linearGradient}>
< Text style = {styles.buttonText} >
Sign in with Facebook
< / Text >
< / LinearGradient >
```
2016-01-19 14:38:09 +02:00
![Example with extra props ](https://raw.githubusercontent.com/brentvatne/react-native-linear-gradient/master/images/example-other-props.png )
2015-03-31 17:48:11 -07:00
2015-04-06 13:49:44 -07:00
### Updating the values for fun
2015-04-06 13:46:12 -07:00
Check out [Examples/AnimatedGradient] (`git clone` this project, cd into it, npm install, open in XCode and run) to see how this is done:
2016-01-19 14:38:09 +02:00
![Example with extra props ](https://raw.githubusercontent.com/brentvatne/react-native-linear-gradient/master/images/example-animated.gif )
2015-04-06 13:49:44 -07:00
2015-04-06 13:46:12 -07:00
*This gif was created using [licecap ](http://www.cockos.com/licecap/ ) - a great piece of free OSS*
2015-03-31 17:48:11 -07:00
### An example app
2016-01-19 14:39:26 +02:00
You can see this component in action in [brentvatne/react-native-login ](https://github.com/brentvatne/react-native-login/blob/master/App/Screens/LoginScreen.js#L58-L62 ).
2015-12-07 10:20:37 -08:00
### License
License is MIT