import React from 'react';
import { Text, View, StyleSheet, Image, Dimensions } from 'react-native';
import ParallaxSwiper from 'react-native-parallax-swiper';
const { width, height } = Dimensions.get('window');
export default class ParallaxSwiperExample extends React.Component {
render() {
let pages = [];
for (let i = 0; i < 5; i++) {
pages.push(
<View key={i}>
<Image
style={styles.backgroundImage}
source={{ uri: `https://source.unsplash.com/user/erondu/daily_${i + 1}` }}
/>
<View style={styles.textContainer}>
<Text style={styles.text}>
这里是第{i + 1}个视图的文本
</Text>
</View>
</View>
);
}
return (
<ParallaxSwiper
style={styles.wrapper}
pages={pages}
parallaxContentStyles={[styles.backgroundImage, styles.backgroundImageBlur]}
onPageChange={(page) => console.log('当前页:', page)}
/>
);
}
}
const styles = StyleSheet.create({
wrapper: {
flex: 1,
},
backgroundImage: {
width,
height,
justifyContent: 'center',
alignItems: 'center',
},
backgroundImageBlur: {
position: 'absolute',
opacity: 0.8,
backgroundColor: 'black',
},
textContainer: {
position: 'absolute',
bottom: 20,
left: 20,
right: 20,
},
text: {
color: 'white',
textAlign: 'center',
fontSize: 20,
},
});
这个代码示例展示了如何使用react-native-parallax-swiper
库创建一个带有视差滑动效果的图片轮播组件。它首先导入了必要的React Native组件和ParallaxSwiper
。然后定义了屏幕宽度和高度的常量,并创建了一个简单的图片URL生成器来为每个页面生成不同的图片。最后,它渲染了ParallaxSwiper
组件,并将生成的图片和文本作为页面内容传递进去。