Files
lx-music-mobile-mod/src/screens/PlayDetail/Portrait/Player/Pic.js
2021-05-21 23:12:50 +08:00

52 lines
1.4 KiB
JavaScript

import React, { memo, useMemo, useState, useEffect } from 'react'
import { View, Image, StyleSheet } from 'react-native'
import { useGetter, useDispatch } from '@/store'
import { useLayout } from '@/utils/hooks'
export default memo(() => {
const playMusicInfo = useGetter('player', 'playMusicInfo')
const [imgUrl, setImgUrl] = useState(null)
const theme = useGetter('common', 'theme')
const { onLayout, ...layout } = useLayout()
useEffect(() => {
const url = playMusicInfo ? playMusicInfo.musicInfo.img : null
if (imgUrl == url) return
setImgUrl(url)
// eslint-disable-next-line react-hooks/exhaustive-deps
}, [playMusicInfo])
const imgWidth = useMemo(() => layout.width * 0.75, [layout.width])
return (
<View style={styles.container} onLayout={onLayout}>
<View style={{ ...styles.content }}>
<Image source={{ uri: imgUrl }} progressiveRenderingEnabled={true} borderRadius={2} style={{
...styles.img,
backgroundColor: theme.primary,
width: imgWidth,
height: imgWidth,
}} />
</View>
</View>
)
})
const styles = StyleSheet.create({
container: {
flexGrow: 1,
flexShrink: 1,
justifyContent: 'center',
alignItems: 'center',
},
content: {
elevation: 3,
backgroundColor: 'rgba(0,0,0,0)',
borderRadius: 4,
},
img: {
borderRadius: 4,
// opacity: 0,
},
})