mirror of
https://github.com/status-im/react-native-blur.git
synced 2025-01-27 16:55:07 +00:00
127 lines
3.6 KiB
Markdown
127 lines
3.6 KiB
Markdown
### React Native Blur
|
|
Component implementation for UIVisualEffectView's blur and vibrancy effect.<br>
|
|
Check the [roadmap here](https://github.com/Kureev/react-native-blur/issues/1)
|
|
|
|
<img src='http://oi62.tinypic.com/8x4u94.jpg' />
|
|
|
|
### Content
|
|
- [Installation](#installation)
|
|
- [Usage example](#usage-example)
|
|
- [Blur view](#blur-view)
|
|
- [Vibrancy view](#vibrancy-view)
|
|
- [Component properties](#component-properties)
|
|
- [Questions?](#questions)
|
|
|
|
### Installation
|
|
1. Install package via npm:
|
|
|
|
```
|
|
npm install react-native-blur
|
|
```
|
|
|
|
2. Link your library by one of those ways: either by using `rnpm link` (see more about rnpm [here](https://github.com/rnpm/rnpm)) or like it's [described here](http://facebook.github.io/react-native/docs/linking-libraries-ios.html).
|
|
3. Inside your code include JS part by adding
|
|
|
|
```javascript
|
|
const { BlurView, VibrancyView } = require('react-native-blur');
|
|
```
|
|
|
|
5. Compile and have fun!
|
|
|
|
### Usage example
|
|
You can run built-in example via few simple steps:
|
|
1. Clone repository
|
|
2. Go to `examples/Basic`
|
|
3. Run `npm install && open Basic.xcodeproj`
|
|
4. Hit "Run"(`cmd+R`) button on XCode panel
|
|
|
|
#### Blur View
|
|
To use `blur` view, you need to require `BlurView` to your module and insert `<BlurView>` tag inside render function as it's done below:
|
|
|
|
```javascript
|
|
const { BlurView } = require('react-native-blur');
|
|
|
|
const Menu = React.createClass({
|
|
render() {
|
|
return (
|
|
<Image source={{uri}} style={styles.menu}>
|
|
<BlurView blurType="light" style={styles.blur}>
|
|
<Text>Hi, I am a tiny menu item</Text>
|
|
</BlurView>
|
|
</Image>
|
|
);
|
|
}
|
|
});
|
|
```
|
|
|
|
In this example, `Image` component will be blurred, a `BlurView` content will stay untouched.
|
|
|
|
#### Vibrancy View
|
|
> The vibrancy effect lets the content underneath a blurred view show through more vibrantly
|
|
|
|
```javascript
|
|
const { VibrancyView } = require('react-native-blur');
|
|
|
|
const Menu = React.createClass({
|
|
render() {
|
|
return (
|
|
<Image source={{uri}} style={styles.menu}>
|
|
<VibrancyView blurType="light" style={styles.blur}>
|
|
<Text>Hi, I am a tiny menu item</Text>
|
|
</VibrancyView>
|
|
</Image>
|
|
);
|
|
}
|
|
});
|
|
```
|
|
|
|
### Component properties
|
|
- `blurType` (String) - blur type effect
|
|
- `xlight` - extra light blur type
|
|
- `light` - light blur type
|
|
- `dark` - dark blur type
|
|
|
|
|
|
### Android
|
|
|
|
Android support uses an [external library](https://github.com/500px/500px-android-blur) which has slightly different properties and setup requirements. You must add the following to the `android/app/build.gradle` file:
|
|
```
|
|
android {
|
|
...
|
|
defaultConfig {
|
|
...
|
|
renderscriptTargetApi 20
|
|
renderscriptSupportModeEnabled true
|
|
}
|
|
}
|
|
|
|
repositories {
|
|
maven { url 'https://github.com/500px/500px-android-blur/raw/master/releases/' }
|
|
}
|
|
|
|
dependencies {
|
|
...
|
|
compile project(':react-native-blur')
|
|
}
|
|
|
|
buildscript {
|
|
repositories {
|
|
maven { url 'https://github.com/500px/500px-android-blur/raw/master/releases/' }
|
|
}
|
|
dependencies {
|
|
classpath 'com.fivehundredpx:blurringview:1.0.0'
|
|
}
|
|
}
|
|
```
|
|
|
|
The android BlurView works by blurring an existing referenced view, so you must wait till the view you want to blur is rendered and then provide the reference to the BlurView as the `viewRef` prop. Take a look at the example to see how it works.
|
|
|
|
It has the following props:
|
|
- `viewRef` (Number) - a reference to the existing view you want to blur
|
|
- `blurRadius` (Number)
|
|
- `downsampleFactor` (Number)
|
|
- `overlayColor` (Color)
|
|
|
|
### Questions?
|
|
Feel free to contact me in [twitter](https://twitter.com/kureevalexey) or [create an issue](https://github.com/Kureev/react-native-blur/issues/new)
|