需求描述:
圖片縮放、拖動、長按保存等基礎圖片查看的功能;
展示每張圖片文本描述;
實現效果,如圖:
實現步驟
使用第三方插件:react-native-image-zoom-viewer
插件GitHub地址:https://github.com/ascoders/react-native-image-viewer
開放參數說明:https://github.com/ascoders/react-native-image-viewer/blob/master/src/image-viewer.type.ts
實現思路:
1.圖集展示部分使用‘react-native-image-zoom-viewer’的ImageViewer控件完整實現;
2.每張圖片的說明使用ScrollView嵌套Text進行展現,ImageViewer開放自定義renderFooter方法,提供當前圖片下標(currentIndex),這樣就可以分別展示每張圖片對於的文字了。
react-native-image-zoom-viewer的使用具體參見GitHub地址的步驟進行配置。
實現代碼:
import React, { Component } from 'react'; import { AppRegistry, StyleSheet, Text, View, Image, Modal, ScrollView, } from 'react-native'; import ImageViewer from 'react-native-image-zoom-viewer'; const images = [{ url: 'http://static.gangguwang.com/image/2017/8/29/16/24/59a524af10f4e8000900198c.jpg' }, { url: 'http://static.gangguwang.com/image/2017/8/29/16/7/59a520d710f4e80009001950.jpg' }]; let imgsDesc = [ "主播上午有事不在公司,拍攝安排被調到了下午,小侯就提前在電腦面前到處瀏覽網站,找下一周視頻的拍攝主題。視頻一旦拍出來就要趕緊制作,剛制作完上傳到網上又要開始下一期欄目的劇本構思,主題內容既要是當下熱點又要能維持熱度直到視頻上傳,還要考慮適合遠近鏡頭的表現和鏡頭的切換等,所以小侯每周最頭疼的事情就是拍攝主題。", "徐小明是陝西西安東嶺旗下的業務員!" ]; class index extends Component { render() { return ( <Modal visible={true} > <ImageViewer imageUrls={images} renderFooter={(currentIndex) => { return ( <ScrollView style={{ height: 70, marginTop: -70 }}> <Text style={{ color: '#fff', paddingLeft: 10, paddingRight: 10 }}>{imgsDesc[currentIndex]}</Text> </ScrollView> ); } } /> </Modal > ); } } const styles = StyleSheet.create({ container: { flex: 1, justifyContent: 'center', alignItems: 'center', backgroundColor: '#fff', } }); module.exports = index;