真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

如何實現(xiàn)Android圖片輪播展示效果

這篇文章主要介紹如何實現(xiàn)Android圖片輪播展示效果,文中介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們一定要看完!

成都創(chuàng)新互聯(lián)公司成立以來不斷整合自身及行業(yè)資源、不斷突破觀念以使企業(yè)策略得到完善和成熟,建立了一套“以技術(shù)為基點,以客戶需求中心、市場為導向”的快速反應(yīng)體系。對公司的主營項目,如中高端企業(yè)網(wǎng)站企劃 / 設(shè)計、行業(yè) / 企業(yè)門戶設(shè)計推廣、行業(yè)門戶平臺運營、成都App制作、手機網(wǎng)站開發(fā)、微信網(wǎng)站制作、軟件開發(fā)、服務(wù)器托管等實行標準化操作,讓客戶可以直觀的預知到從成都創(chuàng)新互聯(lián)公司可以獲得的服務(wù)效果。

實現(xiàn)邏輯

1.創(chuàng)建XML布局文件,使用ViewPager完成輪播圖片

2.初始化ViewPager控件,然后為控件設(shè)置適配器,創(chuàng)建出來的適配器實現(xiàn)里面的四個方法

3.四個方法分別是getCount isViewFromObject instantiateItem destroyItem

4.在onCreat方法中,加載圖片資源,將圖片ID存在集合中,使圖片能夠在頁面中顯示,(圖片之所以能夠在頁面中顯示,是因為在適配器中的instantiateItem方法中獲取了集合中的圖片元素)

5.圖片下方的文字顯示:圖片下方之所以會有文字,可以通過初始化控件,在ViewPager監(jiān)聽器中的onPageSelected方法中tv_desc.setText(descs[position]);這樣文字就可以跟隨者圖片進行切換

6.文字下方的小圓點的切換:在XML布局中設(shè)置一個Linlayout布局,然后再onCreat方法中設(shè)置小圓點,通過LinearLayout.LayoutParams layoutParams = new LinearLayout.LayoutParams(10, 10);的方法引入小圓點(具體代碼可以參考下方的initDot方法)

7.要想讓小圓點隨著頁面的切換而切換,可以定義下方的changeDots的方法,讓此方法在監(jiān)聽器中的onPageSelected方法中進行調(diào)用

8.圖片的無限輪播的實現(xiàn):可以使適配器中的getCount返回值設(shè)為一個很大很大的值,同時在instantiateItem方法中設(shè)置position position = position % imageResIds.length;防止索引越界異常,這樣就可以使圖片無限輪播,但是此時還有一個問題就是,右邊可以無限輪播,但是左邊是無法無限輪播的,這個問題的解決辦法是在onCreat方法中設(shè)置當前選中的條目viewPager.setCurrentItem(count / 2);這樣兩邊都可以實現(xiàn)無限輪播

9.圖片自動切換的處理:使用handler機制實現(xiàn)頁面的延時更新,同時為了防止內(nèi)存溢出,需要在頁面可見時,也就是activity的onStart方法中發(fā)送消息,在頁面消失時,也就是onStop方法中刪除消息

布局文件

<?xml version="1.0" encoding="utf-8"?>







  

  

  

核心代碼

package com.example.a2_;

import android.os.Handler;
import android.os.Message;
import android.support.v4.view.PagerAdapter;
import android.support.v4.view.ViewPager;
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.view.View;
import android.view.ViewGroup;
import android.widget.ImageView;
import android.widget.LinearLayout;
import android.widget.TextView;

import java.util.ArrayList;

public class MainActivity extends AppCompatActivity {
private static final int UPDATE_ITEM = 1;
private ArrayList imageViews = new ArrayList<>();
private int[] imageResIds = {R.mipmap.icon_1, R.mipmap.icon_2, R.mipmap.icon_3,
    R.mipmap.icon_4, R.mipmap.icon_5};

private String[] descs = {"為夢想堅持", "我相信我是黑馬", "黑馬公開課", "Google/IO", "輕松1w+"};
private ViewPager viewPager;
private TextView tv_desc;
private LinearLayout layout_dot;
private int count = 10000000;
private Handler handler = new Handler() {
  @Override
  public void handleMessage(Message msg) {
    switch (msg.what) {
      case UPDATE_ITEM:
        upDataItem();
        break;
    }
    super.handleMessage(msg);
  }
};

@Override
protected void onCreate(Bundle savedInstanceState) {
  super.onCreate(savedInstanceState);
  setContentView(R.layout.activity_main);

  //初始化控件
  viewPager = (ViewPager) findViewById(R.id.vp);
  tv_desc = (TextView) findViewById(R.id.desc);
  layout_dot = (LinearLayout) findViewById(R.id.layout_dot);
  //給viewPager設(shè)置適配器
  viewPager.setAdapter(new MyPagerAdapter());
  //對viewPager設(shè)置監(jiān)聽器
  viewPager.addOnPageChangeListener(new ViewPager.OnPageChangeListener() {

    //當頁面滾動時觸發(fā)的時間
    @Override
    public void onPageScrolled(int position, float positionOffset, int positionOffsetPixels) {

    }

    //當頁面被選中時觸發(fā)的方法
    @Override
    public void onPageSelected(int position) {
      //對position進行處理
      position = position % imageViews.size();
      //當頁面被選中的時候,改變描述文本
      tv_desc.setText(descs[position]);
      changeDots(position);
    }

    //當頁面狀態(tài)滾動狀態(tài)發(fā)生改變時觸發(fā)的事件
    @Override
    public void onPageScrollStateChanged(int state) {
      //當頁面空閑狀態(tài)被改變的時候
      if (state == viewPager.SCROLL_STATE_IDLE) {
        handler.sendEmptyMessageDelayed(UPDATE_ITEM, 3000);
      } else {
        handler.removeMessages(UPDATE_ITEM);
      }
    }
  });


  //初始化圖片
  initImage();
  //初始化文字下方的點
  initDot();
  //當加載頁面的時候,默認讓第一個文本加載出來
//    initDescFirst();

  //使兩邊都可以無限輪播
  viewPager.setCurrentItem(count / 2);
//頁面加載時更新
  upDataItem();
}

private void upDataItem() {
  int index = viewPager.getCurrentItem();
  viewPager.setCurrentItem(++index);
  handler.sendEmptyMessageDelayed(UPDATE_ITEM, 3000);
}

//選中對應(yīng)的原點
private void changeDots(int position) {
  //先把所有的點恢復為白色
  for (int i = 0; i < layout_dot.getChildCount(); i++) {
    View view = layout_dot.getChildAt(i);
    view.setSelected(false);
  }
  //獲取當前被選中的條目 設(shè)置為選中狀態(tài)
  layout_dot.getChildAt(position).setSelected(true);

}

//初始化文字下方的點
private void initDot() {
  LinearLayout.LayoutParams layoutParams = new LinearLayout.LayoutParams(10, 10);
  layoutParams.setMargins(4, 4, 4, 4);
  for (int i = 0; i < imageViews.size(); i++) {
    View view = new View(this);
    view.setBackgroundResource(R.drawable.seletor_dot);
    view.setLayoutParams(layoutParams);
    layout_dot.addView(view);
  }
}

//當加載頁面的時候,默認讓第一個文本加載出來
private void initDescFirst() {
  tv_desc.setText(descs[0]);
  changeDots(0);
}

//添加圖片,準備一個ImageView集合,用來交給instantiateItem添加到頁面
private void initImage() {
  for (int i = 0; i < imageResIds.length; i++) {
    //創(chuàng)建出ImageView對象
    ImageView imageView = new ImageView(getApplicationContext());
    imageView.setImageResource(imageResIds[i]);
    imageViews.add(imageView);
  }
}

private class MyPagerAdapter extends PagerAdapter {

  @Override
  public int getCount() {
    return count;
  }

  @Override
  public boolean isViewFromObject(View view, Object object) {
    //判斷這個view是不是通過instantiateItem創(chuàng)建出來的
    return view == object;
  }

  //用來創(chuàng)建條目
  @Override
  public Object instantiateItem(ViewGroup container, int position) {
    position = position % imageResIds.length;
    //獲取條目
    ImageView imageView = imageViews.get(position);
    container.addView(imageView);
    return imageView;
  }

  //用來銷毀條目,,且最多會創(chuàng)建出三個條目,多出來的條目將會被銷毀
  @Override
  public void destroyItem(ViewGroup container, int position, Object object) {

    //銷毀創(chuàng)建的條目
    container.removeView((View) object);
  }
}

@Override
protected void onStart() {
  super.onStart();
  //當頁面顯示的時候,更新輪播圖
  handler.sendEmptyMessageDelayed(UPDATE_ITEM, 3000);
}

@Override
protected void onStop() {
  super.onStop();
  //當頁面不可見時,停止更新
  handler.removeCallbacksAndMessages(null);
}
}

以上是如何實現(xiàn)Android圖片輪播展示效果的所有內(nèi)容,感謝各位的閱讀!希望分享的內(nèi)容對大家有幫助,更多相關(guān)知識,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道!


當前文章:如何實現(xiàn)Android圖片輪播展示效果
當前鏈接:http://weahome.cn/article/pcdccs.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部