# rntpc_react-native-hole-view
**Repository Path**: openharmony-sig/rntpc_react-native-hole-view
## Basic Information
- **Project Name**: rntpc_react-native-hole-view
- **Description**: No description available
- **Primary Language**: Unknown
- **License**: Not specified
- **Default Branch**: master
- **Homepage**: https://gitee.com/openharmony-sig/rntpc_react-native-hole-view
- **GVP Project**: No
## Statistics
- **Stars**: 0
- **Forks**: 0
- **Created**: 2024-10-14
- **Last Updated**: 2025-05-07
## Categories & Tags
**Categories**: Uncategorized
**Tags**: None
## README
# 🚨 **重要提示 | IMPORTANT**
>
> **⚠️ 此代码仓已归档。新地址请访问 [rntpc_react-native-hole-view](https://gitcode.com/openharmony-sig/rntpc_react-native-hole-view)。| ⚠️ This repository has been archived. For the new address, please visit [rntpc_react-native-hole-view](https://gitcode.com/openharmony-sig/rntpc_react-native-hole-view).**
>
---
>

[](https://npmjs.com/package/react-native-hole-view)
[](https://npmjs.com/package/react-native-hole-view)
## How it works
code
```js
import { RNHoleView } from 'react-native-hole-view';
{"Wow! I'm a text inside a hole!"}
{}} style={{ backgroundColor: 'pink', padding: 10, borderRadius: 5 }}>
{"Wow! I'm a button inside a hole!"}
{
"Wow! I'm a ScrollView inside a hole! Wow! I'm a ScrollView inside a hole! Wow! I'm a ScrollView inside a hole!"
}
```
Works with any nested views:
code
```js
import { RNHoleView } from 'react-native-hole-view
import Video from 'react-native-video';
{"Wow! I'm a text inside a hole!"}
{}} style={{ backgroundColor: 'pink', padding: 10, borderRadius: 5 }}>
{"Wow! I'm a button inside a hole!"}
{
"Wow! I'm a ScrollView inside a hole! Wow! I'm a ScrollView inside a hole! Wow! I'm a ScrollView inside a hole!"
}
```
Can be animated:
code
```js
import {RNHole, RNHoleView, ERNHoleViewTimingFunction, IRNHoleViewAnimation} from "react-native-hole-view";
import Video from 'react-native-video';
const firstHole: RNHole = {x: 150, y: 390, width: 120, height: 120, borderRadius: 60};
const secondHole: RNHole = {x: 150, y: 40, width: 120, height: 120, borderRadius: 60};
const animationSettings: IRNHoleViewAnimation = {timingFunction: ERNHoleViewTimingFunction.EASE_IN_OUT, duration: 200};
const App = () => {
const [holes, setHoles] = useState([]);
const [animated, setAnimated] = useState(false);
const [animation, setAnimation] = useState(undefined);
const onPress = useCallback(() => {
if (animated) {
setHoles([firstHole]);
} else {
setHoles([secondHole])
}
setAnimation({...animationSettings});
setAnimated(!animated);
}, [animated, animation])
useEffect(() => {
onPress();
}, []);
return (
{"Wow! I'm a text inside a hole!"}
{
}} style={{backgroundColor: 'pink', padding: 10, borderRadius: 5}}>
{"Wow! I'm a button inside a hole!"}
{
"Wow! I'm a ScrollView inside a hole! Wow! I'm a ScrollView inside a hole! Wow! I'm a ScrollView inside a hole!"
}
{
setAnimation(undefined);
}}
>
{"Animate!"}
);
};
```
## Getting started
Install the library using either Yarn:
```
yarn add react-native-hole-view
```
or npm:
```
npm install --save react-native-hole-view
```
## Linking
This library fully supports RN's autolinking
## iOS
```
cd ios && pod install
```
## Android
By default RN doesn't support click through views on Android. The solution we [use](https://github.com/ibitcy/react-native-hole-view/blob/master/android/src/main/java/com/ibitcy/react_native_hole_view/RNHoleView.kt) is quite dirty, so please support our PR to FB's react-native repo
https://github.com/facebook/react-native/pull/28956
## Troubleshooting
If you have any diffuculties - please take a look on `example/` app first.
In case you have xcode build error poining on this line
```objectivec
#import "RCTBridgeModule.h"
```
please use version 2.0.*
## Running the example:
1. Clone the repo
2. `cd example`
3. `yarn`
4. `cd ios`
5. `pod install`
6. `cd ..`
7. `yarn run android` or `yarn run ios`