Image組件如何在ReactNative中使用?針對這個問題,這篇文章詳細介紹了相對應的分析和解答,希望可以幫助更多想解決這個問題的小伙伴找到更簡單易行的方法。
創(chuàng)新互聯(lián)建站主營凌云網(wǎng)站建設的網(wǎng)絡公司,主營網(wǎng)站建設方案,手機APP定制開發(fā),凌云h5成都微信小程序搭建,凌云網(wǎng)站營銷推廣歡迎凌云等地區(qū)企業(yè)咨詢Image組件
在ReactNative中Image是用于顯示圖片的組件,和開發(fā)Android的時候ImageView控件相同的效果。它可以用來顯示網(wǎng)絡圖片、靜態(tài)資源、臨時的本地圖片、以及本地磁盤上的圖片(如相冊)等。恰當?shù)氖褂肐mage組件能更形象更直觀的向用戶傳達信息。
Image組件加載項目中的靜態(tài)資源
在這里的靜態(tài)資源指的是加載的js部分的圖片,非android,ios原生應用下的資源文件,對于加載這種圖片資源,我們通過require('圖片文件相對本文件目錄的的路徑')引入圖片文件,并將其設置到Image組件的source屬性即可。如下
<Image style={styles.image} // ./表示當前文件目錄 ../ 父目錄 source={require('./reactlogo.png')} />
需要注意的一點是,上面require中不能用字符串拼接路徑,否則會加載報錯。
加載原生圖片資源
在此所說的原生資源指的我們開發(fā)android的時候再res目錄下的drawable,或者mipmap目錄。以及ios下對應的資源目錄。對于加載這種圖片資源和加載項目中的資源有點不一樣,此處以android為例,如下加載drawable下的文件
<Image source={{uri: 'launcher_icon'}} style={{width: 38, height: 38}} />);
除了通過上面方式加載也可以通過下面方式
<Image source={nativeImageSource({ android: 'launcher_icon', width: 96, height: 96 })} />
nativeImageSource中可以指定圖片寬高,如果同時在image組件的樣式屬性style設置寬高的話,最終寬高是以style中寬高為準。在上面默認加載的是drawable下的圖片資源,如果想加載mipmap中的資源,可以如下
<Image source={nativeImageSource({ android: 'mipmap/launcher_icon', width: 96, height: 96 })} />
通過上面方式,我們就可以加載圖片了,如果是新加到drawable下的圖片需要重新編譯運行,否則是不生效的。
加載網(wǎng)絡圖片
<Image source={{uri: 'https://facebook.github.io/react/img/logo_og.png'}} style={{width: 38, height: 38}} />);
對于加載網(wǎng)絡圖片需要注意的一點就是,需要指定樣式的寬和高,否則圖片將不顯示(不設置默認寬和高為0了)。
Image組件常用的屬性
style:
width :設置圖片的寬
height:設置圖片的高
borderWidth:設置邊框?qū)挾?/p>
borderColor :設置邊框顏色
backgroundColor:設置背景色(有些圖片是透明背景時,一般會用到這個屬性)
opacity:不透明度,值在0到1之間,1表示不透明,0表示透明。
tintColor :給圖片著色,這個屬性用處較多,如,一個黑白圖片,常常會點擊時變成其他顏色圖片,此時可用此屬性
blurRadius 設置圖片的模糊半徑,可模糊圖片
defaultSource 給圖片設置默認圖片,用于加載網(wǎng)絡成功之前顯示的圖片。(ios支持)
source
在上面我們介紹了source屬性加載不同的圖片資源,但是還有一個沒講到,它可以接收一個數(shù)組作為參數(shù),這樣可根據(jù)組件的寬和高自動加載與之匹配的寬和高的圖片。使用方式如下
<Image style={{flex: 1}} source={[ {uri: 'https://facebook.github.io/react/img/logo_small.png', width: 38, height: 38}, {uri: 'https://facebook.github.io/react/img/logo_small_2x.png', width: 76, height: 76}, uri: 'https://facebook.github.io/react/img/logo_og.png', width: 400, height: 400} ]} />
resizeMode
該屬性用來設置圖片的縮放模式,對應值如下
cover:保持圖片寬高比,直到寬度和高度都大于等于容器視圖的尺寸(參考下圖效果)
contain:在保持圖片寬高比的前提下縮放圖片,直到寬度和高度都小于等于容器視圖的尺寸
stretch:拉伸圖片且不維持寬高比,直到寬高都剛好填滿容器
center 居中不拉伸
repeat:重復平鋪圖片直到填滿容器。圖片會維持原始尺寸。(iOS)
在Android上支持GIF和WebP格式圖片
默認情況下Android是不支持GIF和WebP格式的。你需要在build.gradle文件中根據(jù)需要添加對應的依賴。
dependencies { // If your app supports Android versions before Ice Cream Sandwich (API level 14) compile 'com.facebook.fresco:animated-base-support:1.0.1' // For animated GIF support compile 'com.facebook.fresco:animated-gif:1.0.1' // For WebP support, including animated WebP compile 'com.facebook.fresco:animated-webp:1.0.1' compile 'com.facebook.fresco:webpsupport:1.0.1' // For WebP support, without animations compile 'com.facebook.fresco:webpsupport:1.0.1' }
如果你在使用GIF的同時還使用了ProGuard,那么需要在proguard-rules.pro中添加如下規(guī)則
-keep class com.facebook.imagepipeline.animated.factory.AnimatedFactoryImpl { public AnimatedFactoryImpl(com.facebook.imagepipeline.bitmaps.PlatformBitmapFactory, com.facebook.imagepipeline.core.ExecutorSupplier); }
ImageBackground
該組件是Image組件的擴展,它支持嵌套組件。如在圖片上顯示一個文本,則可以通過如下實現(xiàn)
<ImageBackground style={{width: 100, height: 100, backgroundColor: 'transparent'}} source={{uri: 'https://facebook.github.io/react/img/logo_og.png'}} > <Text style={styles.nestedText}> React </Text> </ImageBackground>
實現(xiàn)效果圖如下,一般的我們可以嵌套ActivityIndicator來提示用戶圖片正在加載,當加載完成隱藏此控件。
網(wǎng)絡圖片加載監(jiān)聽
對于網(wǎng)絡圖片的加載,ReactNative提供了一些屬性用于圖片不同加載時期的監(jiān)聽。
onLoadStart:圖片開始加載時調(diào)用
onLoad:圖片加載完成時調(diào)用,此時圖片加載成功
onLoadEnd:加載結(jié)束后調(diào)用,與onLoad不同的是不論成功還是失敗,此回調(diào)函數(shù)都會被執(zhí)行。
使用方法如下
<Image source={{uri:'https://facebook.github.io/react/img/logo_og.png'}} style={[styles.base, {overflow: 'visible'}]} onLoadStart={() => console.log('onLoadStart')} onLoad={(event) => console.log('onLoad') } onLoadEnd={() => console.log('onLoadEnd')} />
對于iOS,還提供了加載進度的回調(diào)函數(shù)onProgress
<Image style={styles.image} onProgress={(event) => { console.log('onProgress') this.setState({ progress: Math.round(100 * event.nativeEvent.loaded / event.nativeEvent.total) })}}/>
可以通過參數(shù)event.nativeEvent.loaded獲取已經(jīng)加載的大小,通過event.nativeEvent.total獲取圖片的總大小。
不僅如此,ReactNative還提供了預加載圖片函數(shù)prefetch(url: string),它可以將圖片下載到磁盤緩存
var prefetchTask = Image.prefetch('https://facebook.github.io/react/img/logo_og.png'); prefetchTask.then(() => { //此處可設置狀態(tài),顯示Image組件。此時組件會使用預加載的圖片信息。而不用再次加載 console.log('加載圖片成功') }, error => { console.log('加載圖片失敗') })
關(guān)于Image組件如何在ReactNative中使用問題的解答就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,如果你還有很多疑惑沒有解開,可以關(guān)注創(chuàng)新互聯(lián)成都網(wǎng)站建設公司行業(yè)資訊頻道了解更多相關(guān)知識。
另外有需要云服務器可以了解下創(chuàng)新互聯(lián)scvps.cn,海內(nèi)外云服務器15元起步,三天無理由+7*72小時售后在線,公司持有idc許可證,提供“云服務器、裸金屬服務器、高防服務器、香港服務器、美國服務器、虛擬主機、免備案服務器”等云主機租用服務以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡單易用、服務可用性高、性價比高”等特點與優(yōu)勢,專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應用場景需求。
網(wǎng)頁標題:Image組件如何在ReactNative中使用-創(chuàng)新互聯(lián)
網(wǎng)址分享:http://muchs.cn/article28/phsjp.html
成都網(wǎng)站建設公司_創(chuàng)新互聯(lián),為您提供營銷型網(wǎng)站建設、用戶體驗、網(wǎng)站營銷、商城網(wǎng)站、小程序開發(fā)、軟件開發(fā)
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)