# react-native-blur
**Repository Path**: harmonytsc_rn/react-native-blur
## Basic Information
- **Project Name**: react-native-blur
- **Description**: No description available
- **Primary Language**: Unknown
- **License**: MIT
- **Default Branch**: master
- **Homepage**: None
- **GVP Project**: No
## Statistics
- **Stars**: 0
- **Forks**: 0
- **Created**: 2025-02-20
- **Last Updated**: 2026-01-27
## Categories & Tags
**Categories**: Uncategorized
**Tags**: None
## README
模板版本:v0.2.2
@ohmi/blur
This project is based on [@react-native-community/blur](https://github.com/react-native-oh-library/react-native-blur)
> [!TIP] [Gitee 地址](https://gitee.com/kunyuan-hongke/react-native-blur)
## 安装与使用
进入到工程目录并输入以下命令:
#### **npm**
```bash
npm install @ohmi/blur
```
#### **yarn**
```bash
yarn add @ohmi/blur
```
下面的代码展示了这个库的基本使用场景:
```js
import React, { useState } from 'react';
import {
Image,
StyleSheet,
Platform,
Switch,
Text,
View,
SafeAreaView,
Dimensions,
} from 'react-native';
import { BlurView, BlurViewProps } from '@react-native-community/blur';
export const Blurs = () => {
const [blurBlurType, setBlurBlurType] =
useState < BlurViewProps['blurType'] > 'dark';
const [blurAmount, setBlurAmount] = useState < number > 100;
useState < BlurViewProps['blurType'] > 'dark';
const tintColor = blurBlurType === 'dark' ? 'white' : 'black';
return (
Blur component ({Platform.OS})
{
setBlurBlurType('light');
}}
>
light
{
setBlurBlurType('dark');
}}
>
dark
{
setBlurBlurType('chromeMaterialLight');
}}
>
chromeMaterialLight click will crash
{
setBlurAmount(20);
}}
>
20
{
setBlurAmount(40);
}}
>
40
{
setBlurAmount(60);
}}
>
60
{
setBlurAmount(80);
}}
>
80
{
setBlurAmount(100);
}}
>
100
);
};
export const BlurDemo = () => {
const [showBlurs, setShowBlurs] = React.useState(false);
//'../assets/bgimage.jpeg' 此路径的图片为本地图片,在使用demo时将此图片的路径换为自己本地图片路径
return (
{showBlurs ? : null}
setShowBlurs(value)}
value={showBlurs}
/>
);
};
const styles = StyleSheet.create({
container: {
flex: 1,
backgroundColor: 'transparent',
},
blurContainer: {
flex: 1,
backgroundColor: 'transparent',
justifyContent: 'center',
alignItems: 'stretch',
},
row: {
marginTop: 50,
flex: 1,
width: '100%',
flexDirection: 'row',
justifyContent: 'space-between',
alignItems: 'stretch',
},
blurView: {
position: 'absolute',
left: 0,
right: 0,
top: 0,
bottom: 0,
width: Dimensions.get('window').width,
},
blurView2: {
position: 'absolute',
left: 0,
right: 0,
top: 0,
bottom: 0,
},
img: {
position: 'absolute',
left: 0,
right: 0,
top: 0,
bottom: 0,
height: Dimensions.get('window').height,
width: Dimensions.get('window').width,
},
text: {
fontSize: 20,
fontWeight: 'bold',
textAlign: 'center',
margin: 10,
color: 'white',
},
blurToggle: {
position: 'absolute',
top: 30,
right: 10,
alignItems: 'flex-end',
},
});
```
## Link
目前 HarmonyOS 暂不支持 AutoLink,所以 Link 步骤需要手动配置。
首先需要使用 DevEco Studio 打开项目里的 HarmonyOS 工程 `harmony`
### 1.在工程根目录的 `oh-package.json5` 添加 overrides 字段
```js
{
...
"overrides": {
"@rnoh/react-native-openharmony" : "./react_native_openharmony"
}
}
```
### 2.引入原生端代码
目前有两种方法:
1. 通过 har 包引入(在 IDE 完善相关功能后该方法会被遗弃,目前首选此方法);
2. 直接链接源码。
方法一:通过 har 包引入
> [!TIP] har 包位于三方库安装路径的 `harmony` 文件夹下。
打开 `entry/oh-package.json5`,添加以下依赖
```json
"dependencies": {
"@rnoh/react-native-openharmony": "file:../react_native_openharmony",
"@ohmi/blur": "file:../../node_modules/@ohmi/blur/harmony/blur.har"
}
```
点击右上角的 `sync` 按钮
或者在终端执行:
```bash
cd entry
ohpm install
```
方法二:直接链接源码
> [!TIP] 如需使用直接链接源码,请参考[直接链接源码说明](/zh-cn/link-source-code.md)
### 3.配置 CMakeLists 和引入 BlurPackage
打开 `entry/src/main/cpp/CMakeLists.txt`,添加:
```diff
project(rnapp)
cmake_minimum_required(VERSION 3.4.1)
set(RNOH_APP_DIR "${CMAKE_CURRENT_SOURCE_DIR}")
+ set(OH_MODULES "${CMAKE_CURRENT_SOURCE_DIR}/../../../oh_modules")
set(RNOH_CPP_DIR "${CMAKE_CURRENT_SOURCE_DIR}/../../../../../../react-native-harmony/harmony/cpp")
add_subdirectory("${RNOH_CPP_DIR}" ./rn)
# RNOH_BEGIN: add_package_subdirectories
add_subdirectory("../../../../sample_package/src/main/cpp" ./sample-package)
+ add_subdirectory("${OH_MODULES}/@ohmi/blur/src/main/cpp" ./blur)
# RNOH_END: add_package_subdirectories
add_library(rnoh_app SHARED
"./PackageProvider.cpp"
"${RNOH_CPP_DIR}/RNOHAppNapiBridge.cpp"
)
target_link_libraries(rnoh_app PUBLIC rnoh)
# RNOH_BEGIN: link_packages
target_link_libraries(rnoh_app PUBLIC rnoh_sample_package)
+ target_link_libraries(rnoh_app PUBLIC rnoh_blur)
# RNOH_END: link_packages
```
打开 `entry/src/main/cpp/PackageProvider.cpp`,添加:
```diff
#include "RNOH/PackageProvider.h"
#include "SamplePackage.h"
+ #include "BlurPackage.h"
using namespace rnoh;
std::vector> PackageProvider::getPackages(Package::Context ctx) {
return {
std::make_shared(ctx),
+ std::make_shared(ctx)
};
}
```
### 4.在 ArkTs 侧引入 BlurView 组件(使用 4.4.0-0.1.0 及之后的版本忽略这步配置)
找到 `function buildCustomRNComponent()`,一般位于 `entry/src/main/ets/pages/index.ets` 或 `entry/src/main/ets/rn/LoadBundle.ets`,添加:
```diff
+ import { BlurView, BLUR_TYPE } from "@ohmi/blur"
@Builder
function buildCustomRNComponent(ctx: ComponentBuilderContext) {
...
+ if (ctx.componentName === BLUR_TYPE) {
+ BlurView({
+ ctx: ctx.rnohContext,
+ tag: ctx.tag,
+ })
+ }
...
}
```
在`entry/src/main/ets/pages/index.ets` 或 `entry/src/main/ets/rn/LoadBundle.ets` 找到常量 `arkTsComponentNames` 在其数组里添加组件名
> [!TIP] 本库使用了混合方案,需要添加组件名。
```diff
const arkTsComponentNames: Array = [
SampleView.NAME,
GeneratedSampleView.NAME,
PropsDisplayer.NAME,
+ BLUR_TYPE
];
```
### 5.运行
点击右上角的 `sync` 按钮
或者在终端执行:
```bash
cd entry
ohpm install
```
然后编译、运行即可。
## 约束与限制
### 兼容性
要使用此库,需要使用正确的 React-Native 和 RNOH 版本。另外,还需要使用配套的 DevEco Studio 和 手机 ROM。
请到三方库相应的 Releases 发布地址查看 Release 配套的版本信息:[@ohmi/blur Releases](https://gitee.com/kunyuan-hongke/react-native-blur/releases)
## 属性
> [!TIP] "Platform"列表示该属性在原三方库上支持的平台。
> [!TIP] "HarmonyOS Support"列为 yes 表示 HarmonyOS 平台支持该属性;no 则表示不支持;partially 表示部分支持。使用方法跨平台一致,效果对标 iOS 或 Android 的效果。
| Name | Description | Type | Required | Platform | HarmonyOS Support |
| ----------------------------------- | ----------------------------------------------------------------------------------------- | --------- | -------- | ----------- | ----------------- |
| `blurType` | blur type | enum | yes | iOS,Android | yes |
| `blurAmount?` | 0 - 100 (The maximum blurAmount on Android is 32, so higher values will be clamped to 32) | number | no | iOS,Android | yes |
| `reducedTransparencyFallbackColor?` | Reduce transparency fallback color | Any color | no | iOS | no |
| `blurRadius?` | Matches iOS blurAmount | number | no | Android | no |
| `downsampleFactor?` | Matches iOS blurAmount | number | no | Android | no |
| `overlayColor?` | Default color based on iOS blurType | Any color | no | Android | no |
#### blurType
> [!TIP] 如果要使用自适应模糊效果需要配置深色模式[配置文档](https://developer.huawei.com/consumer/cn/doc/harmonyos-guides-V5/arkts-light-dark-color-adaptation-V5#section1421172621111)如果不配置深色模式则自适应模糊效果将没有深色模式,只有浅色模式。
| Name | Description | Platform | HarmonyOS Support |
| ------------------------ | ------------------------------------------------------------------------------------------------------ | ----------- | ----------------- |
| `xlight` | extra light blur type | iOS,Android | yes |
| `light` | light blur type | iOS,Android | yes |
| `dark` | dark blur type | iOS,Android | yes |
| `extraDark` | extra dark blur type (tvOS only) | iOS | yes |
| `regular` | regular blur type (iOS 10+ and tvOS only) | iOS | yes |
| `prominent` | prominent blur type (iOS 10+ and tvOS only) | iOS | yes |
| `chromeMaterial` | An adaptable blur effect that creates the appearance of a material with normal thickness | iOS 13 only | yes |
| `material` | An adaptable blur effect that creates the appearance of a material with normal thickness | iOS 13 only | yes |
| `thickMaterial` | An adaptable blur effect that creates the appearance of a material that is thicker than normal | iOS 13 only | yes |
| `thinMaterial` | An adaptable blur effect that creates the appearance of an ultra-thin material | iOS 13 only | yes |
| `ultraThinMaterial` | An adaptable blur effect that creates the appearance of an ultra-thin material | iOS 13 only | yes |
| `chromeMaterialDark` | A blur effect that creates the appearance of an ultra-thin material and is always dark | iOS 13 only | yes |
| `materialDark` | A blur effect that creates the appearance of a thin material and is always dark | iOS 13 only | yes |
| `thickMaterialDark` | A blur effect that creates the appearance of a material with normal thickness and is always dark | iOS 13 only | yes |
| `thinMaterialDark` | A blur effect that creates the appearance of a material that is thicker than normal and is always dark | iOS 13 only | yes |
| `ultraThinMaterialDark` | A blur effect that creates the appearance of the system chrome and is always dark | iOS 13 only | yes |
| `chromeMaterialLight` | An adaptable blur effect that creates the appearance of the system chrome | iOS 13 only | yes |
| `materialLight` | An adaptable blur effect that creates the appearance of a material with normal thickness | iOS 13 only | yes |
| `thickMaterialLight` | An adaptable blur effect that creates the appearance of a thin material | iOS 13 only | yes |
| `thinMaterialLight` | An adaptable blur effect that creates the appearance of a thin material | iOS 13 only | yes |
| `ultraThinMaterialLight` | An adaptable blur effect that creates the appearance of an ultra-thin material | iOS 13 only | yes |
## API
> [!TIP] "Platform"列表示该组件在原三方库上支持的平台。
> [!TIP] "HarmonyOS Support"列为 yes 表示 HarmonyOS 平台支持该组件;no 则表示不支持;partially 表示部分支持。使用方法跨平台一致,效果对标 iOS 或 Android 的效果。
| Name | Description | Type | Required | Platform | HarmonyOS Support |
| -------------- | ------------------------------------------------------------------------------------------ | --------- | -------- | ----------- | ----------------- |
| `BlurView` | Preload images to display later. e.g. | component | no | iOS,Android | yes |
| `VibrancyView` | The vibrancy effect lets the content underneath a blurred view show through more vibrantly | component | no | iOS | no |
## 遗留问题
- [ ] @react-native-community/blur 的 VibrancyView 组件未实现 HarmonyOS 化 [issue#7](https://github.com/react-native-oh-library/react-native-blur/issues/7)
- [ ] @react-native-community/blur 的 reducedTransparencyFallbackColor 属性未实现 HarmonyOS 化[issue#8](https://github.com/react-native-oh-library/react-native-blur/issues/8)
## 其他
## 开源协议
本项目基于 [The MIT License (MIT)](https://gitee.com/kunyuan-hongke/react-native-blur/blob/master/LICENSE) ,请自由地享受和参与开源。