gpt4 book ai didi

react-native - 滑动时水平暂停 FlatList 上的视频

转载 作者:行者123 更新时间:2023-12-04 10:44:44 26 4
gpt4 key购买 nike

在使用 FlatList 滑动时,我可以控制台记录可查看项目,但我想知道如何管理暂停视频。或者如果有更好的方法来这样做?

这是RenderItem函数组件

const RenderItem = (props) => {
const [paused, setPaused] = useState(true);

const togglePlay = () => setPaused(prev => !prev);

return (
<View>
{props.is_video ? (
<>
<Video
paused={paused}
repeat
source={{uri: props.mediaUrl}}
/>
<TouchableWithoutFeedback onPress={togglePlay}>
<View>
{paused ? <Icon
size={180}
name="play"
type="FontAwesome"
style={{opacity: 0.7, color: '#cccccc'}}
/> : null}
</View>
</TouchableWithoutFeedback>
</>
) : (
<Image source={{uri: props.mediaUrl}} />
)}
</View>
);
};

然后在另一个函数中,我有这个:
const Post = (props) => {

const onViewRef = useRef((viewableItems)=> {console.log(viewableItems)});
const viewConfigRef = useRef({ viewAreaCoveragePercentThreshold: 50 });

return (
<View style={{flex: 1}}>
<View>
<FlatList
onViewableItemsChanged={onViewRef.current}
viewabilityConfig={viewConfigRef.current}
data={props.navigation.state.params.media}
snapToAlignment={'center'}
horizontal
decelerationRate={'fast'}
pagingEnabled
renderItem={({item}) => <RenderItem {...item} />}
keyExtractor={item => item.mediaUrl}
/>
</View>
</View>
);
};

我可以按下视频,它会播放或暂停。当我现在滑动时,视频会继续播放。我希望能够确保在滑动时,播放的视频现在会暂停。

最佳答案

您可以将暂停/播放状态提升到父组件 ( Post )。由于任何时候最多只能播放 1 个视频,因此状态可以简单地存储当前正在播放的项目 ID(或 mediaUrl,如果您将其用作键/ID)。

RenderItem :

<Video paused={props.paused} ... />
<TouchableWithoutFeedback onPress={props.onTogglePlay}>

Post (您可以将 useCallback 用于匿名函数):
const [activeVideo, setActiveVideo] = useState(null);
...
<FlatList onViewableItemsChanged={() => setActiveVideo(null)} .../>
...
<RenderItem
paused={activeVideo !== item.mediaUrl}
onTogglePlay={() =>
setActiveVideo(item.mediaUrl === activeVideo ? null : item.mediaUrl)
}
{...item}
/>

您还可以存储对事件视频的引用并通过该引用暂停视频。

关于react-native - 滑动时水平暂停 FlatList 上的视频,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/59757370/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com