React-Native 中實(shí)現(xiàn)圖片定時器

  • 效果圖


    222.gif
  • 結(jié)構(gòu)


    Snip20160404_8.png
  • 在render函數(shù)中表現(xiàn)為:

      render(){
          return(
               <View style={styles.container}>
                  <ScrollView
                  >
                  {this.renderCycleImages()}
                  </ScrollView>
    
                  <View style = {styles.pageViewStyle}>
                  {this.renderPageIndicator()}
                   </View>
              </View>
          )
       },
    

1:首先實(shí)現(xiàn)的效果

Snip20160404_6.png
  • 導(dǎo)入相應(yīng)的類

      import React, {
          AppRegistry,
      Component,
      StyleSheet,
          View,
          Image,
          Text,
          ScrollView,
    
          } from 'react-native';
    
  • 導(dǎo)入JSON數(shù)據(jù)和獲取屏幕數(shù)據(jù)的類庫

      import ImagesData from './component/ImageData.json';
      import Dimensions from  'Dimensions';
    
  • renderCycleImages函數(shù)中加載圖片

    • 我是把圖片放在 Images.xcassets

      renderCycleImages(){
          var datas = ImagesData.data;
          var allImages = [ ];
      
          for(var i=0; i< datas.length; i++){
              allImages.push(
            <Image 
             key={i}
             source={{uri: datas[i].img}}
             style={styles.imagesStyle}/>
        );
         }
      
         return allImages;
         }
      
    • 圖片樣式

      imagesStyle:{
      width:width,
      height:width * 0.5,
      },

  • renderPageIndicator函數(shù)中加載 圖片指示器

    • 加載 圖片指示器

        var allCycle =  [ ];
      
        for (var i= 0; i< ImagesData.data.length; i++){
      
        allCycle.push(
            <Text key = {i} style = {styles.pageCircleStyle}>?</Text>
        )
         }
      
        return allCycle;
         }
      
    • pageViewStyle 樣式
      pageViewStyle:{
      flexDirection:'row',
      width:width,
      height:30,
      backgroundColor:'rgba(222,222,222,0.6)',

          position:'absolute',
              bottom:0,
      
              alignItems:'center',
              justifyContent:'center'
          },
      
    • 圖片指示器樣式

         pageCircleStyle:{
             fontSize:30,
                 marginLeft:5
      },
      
  • 注意

    • 1.若不綁定( key = {i})一個唯一標(biāo)識,


      Snip20160404_2.png
    • 2.ScrollView默認(rèn)是垂直樣式

        <ScrollView
            horizontal={true}
            pagingEnabled={true}
            showsHorizontalScrollIndicator={false}
            
            >  
      
    • 3.把圖片沒有展示出來

        圖片若沒設(shè)置大小蜕劝,將不顯示
        還有一點(diǎn):不能滑動,設(shè)置flex:1
      

2. 實(shí)現(xiàn)手動滾動

- 大致思路:給圖片指示器添加樣式宜鸯。如果當(dāng)前頁與圖片指示器的值相等,則為紅色围段,否則為白色.

- 給定一個初始的頁碼
     
        getInitialState(){
            return{
                 currentPage:0
             }
        },
- 指示器中的代碼表現(xiàn)為:
    
        renderPageIndicator(){

           var allCycle = [ ];
           var style;

            for (var i= 0; i< ImagesData.data.length; i++){
            //判斷是否是當(dāng)前頁
            style = (i == this.state.currentPage)? {color:'red'} :{color:'white'};

            allCycle.push(
            <Text key = {i} style = {[styles.pageCircleStyle,style]}>?</Text>
        )
      }

      return allCycle;
        },
  • OnMomentumScrollEnd 當(dāng)一幀滾動完畢的時候調(diào)用
    • e.nativeEvent.contentOffset顾翼。拿到偏移量,進(jìn)而求出當(dāng)前頁碼奈泪,再更新當(dāng)前頁

        onAnimationEnd(e){
        var offSetX = e.nativeEvent.contentOffset.x;
      
           var currentPage = Math.floor(offSetX/width);
      
        // 更新狀態(tài)
        this.setState({
             currentPage: currentPage
            });
        },
      

3.加入定時器

  • 需要導(dǎo)入計時器類庫 npm i react-timer-mixin --save

    • 在項(xiàng)目中需要引入并注冊:
      • 引入: var TimerMixin = require('react-timer-mixin');
      • 注冊:mixins: [TimerMixin],
  • componentDidMount函數(shù)中開啟定時器,一般網(wǎng)絡(luò)請求灸芳,異步處理都在這個函數(shù)中處理

    • 設(shè)置一個初始值涝桅,

        getDefaultProps(){
            return{
            timer:1000
            }
        },
      
    • 開啟定時器

        startTimer(){
            var scrollView = this.refs.scrollView;
            var imagesCount = ImagesData.data.length;
      
          this.timer = this.setInterval(function () {
      
         // 設(shè)置臨時頁碼
         var activePage;
      
         if((this.state.currentPage + 1) >=imagesCount ){
                activePage = 0;
            }else{
                activePage = this.state.currentPage + 1;
            };
      
            var currentX = activePage * width;
             scrollView.scrollResponderScrollTo({x:currentX,y:0,animated:true});
      
             this.setState({
             currentPage:activePage
        });
      
        },this.props.timer)
         },
      
  • 完善

    • onScrollEndDrag 停止拖拽函數(shù)中,開啟定時器

    • onScrollBeginDrag 開始拖拽函數(shù)中烙样,清除定時器

      onScrollEndDrag(){
      this.startTimer();
      },

        onScrollBeginDrag(){
      
          this.clearInterval(this.timer);
        },
      
  • render函數(shù)最終表現(xiàn)為

      render(){
      return(
          <View style={styles.container}>
              <ScrollView
              ref = 'scrollView'
              horizontal={true}
              pagingEnabled={true}
              showsHorizontalScrollIndicator={false}
              onMomentumScrollEnd={this.onAnimationEnd}
              onScrollEndDrag={this.onScrollEndDrag}
              onScrollBeginDrag={this.onScrollBeginDrag}
              >
                  {this.renderCycleImages()}
              </ScrollView>
    
              <View style = {styles.pageViewStyle}>
                  {this.renderPageIndicator()}
              </View>
          </View>
      )
    

    },

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末冯遂,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子谒获,更是在濱河造成了極大的恐慌蛤肌,老刑警劉巖,帶你破解...
    沈念sama閱讀 207,113評論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件批狱,死亡現(xiàn)場離奇詭異裸准,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)赔硫,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,644評論 2 381
  • 文/潘曉璐 我一進(jìn)店門炒俱,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人,你說我怎么就攤上這事权悟≡彝酰” “怎么了?”我有些...
    開封第一講書人閱讀 153,340評論 0 344
  • 文/不壞的土叔 我叫張陵峦阁,是天一觀的道長谦铃。 經(jīng)常有香客問我,道長榔昔,這世上最難降的妖魔是什么荷辕? 我笑而不...
    開封第一講書人閱讀 55,449評論 1 279
  • 正文 為了忘掉前任,我火速辦了婚禮件豌,結(jié)果婚禮上疮方,老公的妹妹穿的比我還像新娘。我一直安慰自己茧彤,他們只是感情好骡显,可當(dāng)我...
    茶點(diǎn)故事閱讀 64,445評論 5 374
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著曾掂,像睡著了一般惫谤。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上珠洗,一...
    開封第一講書人閱讀 49,166評論 1 284
  • 那天溜歪,我揣著相機(jī)與錄音,去河邊找鬼许蓖。 笑死蝴猪,一個胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的膊爪。 我是一名探鬼主播自阱,決...
    沈念sama閱讀 38,442評論 3 401
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼米酬!你這毒婦竟也來了沛豌?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 37,105評論 0 261
  • 序言:老撾萬榮一對情侶失蹤赃额,失蹤者是張志新(化名)和其女友劉穎加派,沒想到半個月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體跳芳,經(jīng)...
    沈念sama閱讀 43,601評論 1 300
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡芍锦,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,066評論 2 325
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了筛严。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片醉旦。...
    茶點(diǎn)故事閱讀 38,161評論 1 334
  • 序言:一個原本活蹦亂跳的男人離奇死亡饶米,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出车胡,到底是詐尸還是另有隱情檬输,我是刑警寧澤,帶...
    沈念sama閱讀 33,792評論 4 323
  • 正文 年R本政府宣布匈棘,位于F島的核電站丧慈,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏主卫。R本人自食惡果不足惜逃默,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,351評論 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望簇搅。 院中可真熱鬧完域,春花似錦、人聲如沸瘩将。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,352評論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽姿现。三九已至肠仪,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間备典,已是汗流浹背异旧。 一陣腳步聲響...
    開封第一講書人閱讀 31,584評論 1 261
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留提佣,地道東北人吮蛹。 一個月前我還...
    沈念sama閱讀 45,618評論 2 355
  • 正文 我出身青樓,卻偏偏與公主長得像镐依,于是被迫代替她去往敵國和親匹涮。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 42,916評論 2 344

推薦閱讀更多精彩內(nèi)容

  • 前言 學(xué)習(xí)本系列內(nèi)容需要具備一定 HTML 開發(fā)基礎(chǔ)槐壳,沒有基礎(chǔ)的朋友可以先轉(zhuǎn)至 HTML快速入門(一) 學(xué)習(xí) 本人...
    珍此良辰閱讀 29,995評論 15 29
  • Swift圖片輪播 效果圖 核心思想一個UIScrollView,三個UIImageView喜每,一個[UIImage...
    ZhHS閱讀 2,190評論 2 14
  • 單例模式 適用場景:可能會在場景中使用到對象务唐,但只有一個實(shí)例,加載時并不主動創(chuàng)建带兜,需要時才創(chuàng)建 最常見的單例模式枫笛,...
    Obeing閱讀 2,056評論 1 10
  • 前言 學(xué)習(xí)本系列內(nèi)容需要具備一定 HTML 開發(fā)基礎(chǔ),沒有基礎(chǔ)的朋友可以先轉(zhuǎn)至 HTML快速入門(一) 學(xué)習(xí) 本人...
    珍此良辰閱讀 13,321評論 11 24
  • 小馬刚照,我的同事刑巧,一個外表纖細(xì)的上海“不作”女子,年方三八啊楚。 初識小馬爸爸是六年前吠冤。當(dāng)時小馬有孕在身,某次產(chǎn)檢時因指...
    B123閱讀 403評論 0 4