Security News
Bun 1.2 Released with 90% Node.js Compatibility and Built-in S3 Object Support
Bun 1.2 enhances its JavaScript runtime with 90% Node.js compatibility, built-in S3 and Postgres support, HTML Imports, and faster, cloud-first performance.
react-native-ios-visual-effect-view
Advanced tools
A small library to use UIVisualEffectView
in react-native
.
VisualEffectCustomFilterViewTest01Screen
VisualEffectCustomFilterViewTest01Screen
This library + documentation is currently not finished yet. For now, please browse through examples directory to get a rough idea on how to use this library. Jump to basic usage section for example code + gif.
very special thanks to: junzhengca, brentvatne, expo, EvanBacon, corasan, lauridskern, ronintechnologies, and gerzonc for becoming a monthly sponsor, and thank you fobos531 for being a one time sponsor 🥺 (if you have the means to do so, please considering sponsoring here)
https://github.com/user-attachments/assets/74bf8afa-91ed-49d8-80aa-a17b8e7969b0
https://github.com/user-attachments/assets/16d2c2ee-5453-43ea-bd3f-aa8331fbcd58
UIVisualEffectView
+ all the system UIBlurEffectStyles
.The example app builds are automatically created and submitted on every version release via Xcode cloud, so if you just want to quickly try things out, the example app is available to try out via testflight (invite link).
Alternatively, you can also try out the corresponding example app to the native dependency that this library uses under the hood: VisualEffectBlurView
(invite link).
Experiment02ViewController.swift
VisualEffectBlurTestViewController.swift
VisualEffectViewExperiment01ViewController.swift
VisualEffectCustomFilterViewTest02Controller.swift
Note: Support for the new architecture (fabric), and backwards compatibility for the old architecture (paper) is handled via a peer dependency to react-native-ios-utilites@v5
.
# 1. install library + dependencies
npm install react-native-ios-visual-effect-view@next
npm install react-native-ios-utilities@next
# 2. then run pod install (uses auto-linking)
cd ios && pod install
This library has cocoapods dependency to VisualEffectBlurView
and DGSwiftUtilities
, so you may need to update them separately (as needed).
# A. Either update this specific pod...
pod update VisualEffectBlurView DGSwiftUtilities
pod install --repo-update
# B. Or update all the pods
pod update
hello! please see BlurViewBasicUsage01
for the full example
// 📝 Note: for the sake of brevity, some of the code is omitted...
import { BlurView } from 'react-native-ios-visual-effect-view';
export function BlurViewBasicUsage01() {
return (
<View style={styles.container}>
<Text style={styles.label}>
{'❤️\n🧡\n💛\n💚\n💙\n💜\n💖\n💃\n✨'}
</Text>
<RNIBlurView
style={styles.effectOverlay}
blurMode={{
mode: 'blurEffectSystem',
blurEffectStyle: 'prominent',
}}
animationConfig={{
duration: 1,
mode: 'presetCurve',
curve: 'easeOut',
}}
animationDelay={1}
/>
</View>
);
}
TBA
Please see the examples directory for the full list of examples, demos and tests.
CustomFilterViewExample01
Summary: Create a custom filter that darkens the views in the background, and applies a variable blur.
Notes |
---|
1️⃣ — The CustomFilterView.currentFilters prop accepts a CustomFilterConfig object; this object is used create and configure the underlying UIVisualEffectView effects.The CustomFilterConfig is comprised of several properties, but for this example we will be focusing on the CustomFilterConfig.backgroundFilters property (since it's required). |
2️⃣ — The CustomFilterConfig.backgroundFilters property accepts an array of LayerFilterConfig object; the "filter entries" in this array defines what filters to use for the UIVisualEffectView 's backdrop layer.The backdrop layer is special in that it is able to composite views that are behind it, and apply filters to it. 📝 Note: The "quality" of the composited views can be controlled via the CustomFilterView.backgroundLayerSamplingSizeScale prop; Setting this to 2.0 increases the sampling size, but at the cost of performance (use with caution). |
3️⃣ — The LayerFilterConfig object is an tagged union type, with the LayerFilterConfig.filterName property being the "discriminant" that separates all the possible combinations.The filterName defines what type of filter to use; different types of filters have different inputs to control the look/behavior of the desired effect.In the example below, we define 4 LayerFilterConfig entries in the array for the CustomFilterConfig.backgroundFilters property: variadicBlur (variable blur), colorBlackAndWhite (color monochrome), brightenColors (color brightness), and contrastColors (color contrast).📝 Note: The names for the filter are a bit weird because we can't use the internal filters directly. Please see LayerFilterTypeName.swift for the implementation details. |
export function CustomFilterViewExample01() {
return (
<View style={styles.container}>
<Text style={styles.label}>
{emojiString}
</Text>
<CustomFilterView
style={styles.effectOverlay}
// increase quality (usually: 0.25...1)
backgroundLayerSamplingSizeScale={2}
// set the filters to use,
// accepts an array of `LayerFilterConfig`
currentFilters={{
backgroundFilters: [
// filter 1 of 4
// create variable blur filter
{
filterName: 'variadicBlur',
radius: 8,
shouldNormalizeEdges: true,
// define the intensity of blur via a gradient
gradientMask: {
type: 'axial',
colors: [
'rgba(0,0,0,1)', // max blur
'rgba(0,0,0,0)', // no blur
],
startPointPreset: 'topCenter',
endPointPreset: 'bottomCenter',
size: {
height: WINDOW_SIZE.height,
width: WINDOW_SIZE.width,
},
}
},
// filter 2 of 4
// Slightly desaturate colors
{
filterName: 'colorBlackAndWhite',
amount: 0.5
},
// filter 3 of 4
// reduce brightness
{
filterName: 'brightenColors',
amount: -0.5
},
// filter 4 of 4
// decrease contrast
{
filterName: 'contrastColors',
amount: 0.4,
},
]
}}
>
<Text>
{'Hello World'}
</Text>
</CustomFilterView>
</View>
);
}
CustomFilterViewExample02
Summary: TBA
export function CustomFilterViewExample02() {
// ...
return (
<View style={styles.container}>
{ /* ... */ }
<CustomFilterView
style={styles.effectOverlay}
backgroundLayerSamplingSizeScale={2}
currentFilters={{
backgroundFilters: [
{
filterName: 'gaussianBlur',
radius: 18,
shouldNormalizeEdges: true,
},
{
filterName: 'brightenColors',
amount: -0.5
},
{
filterName: 'contrastColors',
amount: 0.3,
},
{
filterName: 'colorBlackAndWhite',
amount: 1,
},
],
tintConfig: {
opacity: 0.75,
blendMode: 'color',
tintColor: 'red',
},
foregroundFilters: [
{
filterName: 'gaussianBlur',
radius: 4,
shouldNormalizeEdges: false
},
{
filterName: 'colorMatrixVibrant',
colorMatrix: {
mode: 'preset',
preset: {
mode: 'presetName',
presetName: 'preset14'
},
},
},
]
}}
>
<View style={styles.effectContent}>
<CounterDisplay
counter={counter}
/>
</View>
</CustomFilterView>
</View>
);
}
See the contributing guide to learn how to contribute to the repository and the development workflow.
MIT
Made with create-react-native-library
FAQs
TBA
The npm package react-native-ios-visual-effect-view receives a total of 7 weekly downloads. As such, react-native-ios-visual-effect-view popularity was classified as not popular.
We found that react-native-ios-visual-effect-view demonstrated a healthy version release cadence and project activity because the last version was released less than a year ago. It has 0 open source maintainers collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Security News
Bun 1.2 enhances its JavaScript runtime with 90% Node.js compatibility, built-in S3 and Postgres support, HTML Imports, and faster, cloud-first performance.
Security News
Biden's executive order pushes for AI-driven cybersecurity, software supply chain transparency, and stronger protections for federal and open source systems.
Security News
Fluent Assertions is facing backlash after dropping the Apache license for a commercial model, leaving users blindsided and questioning contributor rights.