欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

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

 更新時(shí)間:2020年12月22日 11:41:33   作者:常利兵  
這篇文章主要為大家詳細(xì)介紹了Android實(shí)現(xiàn)輪播圖片展示效果,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下

本文實(shí)例為大家分享了Android輪播圖片的展示,供大家參考,具體內(nèi)容如下

實(shí)現(xiàn)邏輯

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

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

3.四個(gè)方法分別是getCount isViewFromObject instantiateItem destroyItem

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

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

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

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

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

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

布局文件

<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:id="@+id/activity_main"
android:layout_width="match_parent"
android:layout_height="match_parent"
tools:context="com.example.a2_.MainActivity">

<android.support.v4.view.ViewPager
 android:id="@+id/vp"
 android:layout_width="match_parent"
 android:layout_height="250dp">
</android.support.v4.view.ViewPager>

<LinearLayout
 android:orientation="vertical"
 android:gravity="center"
 android:background="#66000000"
 android:layout_alignBottom="@id/vp"
 android:layout_width="match_parent"
 android:layout_height="50dp">

 <TextView
  android:id="@+id/desc"
  android:text="描述文本"
  android:textColor="#ffffff"
  android:layout_width="wrap_content"
  android:layout_height="wrap_content" />

 <LinearLayout
  android:id="@+id/layout_dot"
  android:orientation="horizontal"
  android:layout_width="wrap_content"
  android:layout_height="wrap_content">

 </LinearLayout>
</LinearLayout>
</RelativeLayout>

核心代碼

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<ImageView> 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 = {"為夢(mèng)想堅(jiān)持", "我相信我是黑馬", "黑馬公開(kāi)課", "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());
 //對(duì)viewPager設(shè)置監(jiān)聽(tīng)器
 viewPager.addOnPageChangeListener(new ViewPager.OnPageChangeListener() {

  //當(dāng)頁(yè)面滾動(dòng)時(shí)觸發(fā)的時(shí)間
  @Override
  public void onPageScrolled(int position, float positionOffset, int positionOffsetPixels) {

  }

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

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


 //初始化圖片
 initImage();
 //初始化文字下方的點(diǎn)
 initDot();
 //當(dāng)加載頁(yè)面的時(shí)候,默認(rèn)讓第一個(gè)文本加載出來(lái)
//  initDescFirst();

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

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

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

}

//初始化文字下方的點(diǎn)
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);
 }
}

//當(dāng)加載頁(yè)面的時(shí)候,默認(rèn)讓第一個(gè)文本加載出來(lái)
private void initDescFirst() {
 tv_desc.setText(descs[0]);
 changeDots(0);
}

//添加圖片,準(zhǔn)備一個(gè)ImageView集合,用來(lái)交給instantiateItem添加到頁(yè)面
private void initImage() {
 for (int i = 0; i < imageResIds.length; i++) {
  //創(chuàng)建出ImageView對(duì)象
  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) {
  //判斷這個(gè)view是不是通過(guò)instantiateItem創(chuàng)建出來(lái)的
  return view == object;
 }

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

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

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

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

@Override
protected void onStop() {
 super.onStop();
 //當(dāng)頁(yè)面不可見(jiàn)時(shí),停止更新
 handler.removeCallbacksAndMessages(null);
}
}

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • Android自定義View之自定義評(píng)價(jià)打分控件RatingBar實(shí)現(xiàn)自定義星星大小和間距

    Android自定義View之自定義評(píng)價(jià)打分控件RatingBar實(shí)現(xiàn)自定義星星大小和間距

    Android開(kāi)發(fā)中,我們經(jīng)常會(huì)用到對(duì)商家或者商品的評(píng)價(jià),運(yùn)用星星進(jìn)行打分。這篇文章介紹了Android自定義View之自定義評(píng)價(jià)打分控件RatingBar可以自定義星星大小和間距的相關(guān)資料,感興趣的朋友一起看看吧
    2016-10-10
  • Android自定義view之太極圖的實(shí)現(xiàn)教程

    Android自定義view之太極圖的實(shí)現(xiàn)教程

    這篇文章主要給大家介紹了關(guān)于Android自定義view之太極圖的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2021-01-01
  • Flutter中數(shù)據(jù)庫(kù)的使用教程詳解

    Flutter中數(shù)據(jù)庫(kù)的使用教程詳解

    在Flutter開(kāi)發(fā)過(guò)程中,有時(shí)需要對(duì)數(shù)據(jù)進(jìn)行本地的持久化存儲(chǔ),使用sp文件形式雖然也能解決問(wèn)題,但是有時(shí)數(shù)據(jù)量較大的時(shí)候,顯然我們文件形式就不太合適了,這時(shí)候我們就需要使用數(shù)據(jù)庫(kù)進(jìn)行存儲(chǔ)。本文將詳細(xì)講講Flutter中數(shù)據(jù)庫(kù)的使用,需要的可以參考一下
    2022-04-04
  • Android編程實(shí)現(xiàn)擦除Bitmap中某一塊的方法

    Android編程實(shí)現(xiàn)擦除Bitmap中某一塊的方法

    這篇文章主要介紹了Android編程實(shí)現(xiàn)擦除Bitmap中某一塊的方法,涉及Android操作Bitmap顏色像素值調(diào)整的相關(guān)技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下
    2015-11-11
  • Flutter?GridView顯示隨機(jī)單詞效果

    Flutter?GridView顯示隨機(jī)單詞效果

    這篇文章主要為大家詳細(xì)介紹了Flutter?GridView顯示隨機(jī)單詞效果,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-03-03
  • Android Broadcast原理分析之registerReceiver詳解

    Android Broadcast原理分析之registerReceiver詳解

    這篇文章主要介紹了Android Broadcast原理分析之registerReceiver詳解,本篇文章通過(guò)簡(jiǎn)要的案例,講解了該項(xiàng)技術(shù)的了解與使用,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下
    2021-08-08
  • android簡(jiǎn)易文件管理器實(shí)例(列表式文件目錄)

    android簡(jiǎn)易文件管理器實(shí)例(列表式文件目錄)

    下面小編就為大家?guī)?lái)一篇android簡(jiǎn)易文件管理器實(shí)例(列表式文件目錄)。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2017-04-04
  • Android簽名知識(shí)小結(jié)

    Android簽名知識(shí)小結(jié)

    不止一次有用到Android簽名相關(guān)的知識(shí),每次都幾乎從零開(kāi)始在Google上搜索找,不想在繼續(xù)這樣了,找了個(gè)時(shí)間好好整理了一下自己用到的一些碎片知識(shí),于是乎放到這里,一是備忘,二是幫助別人
    2016-03-03
  • Android搜索框組件SearchView的基本使用方法

    Android搜索框組件SearchView的基本使用方法

    這篇文章主要為大家詳細(xì)介紹了Android搜索框組件SearchView的基本使用方法,感興趣的小伙伴們可以參考一下
    2016-05-05
  • Flutter UI如何使用Provide實(shí)現(xiàn)主題切換詳解

    Flutter UI如何使用Provide實(shí)現(xiàn)主題切換詳解

    這篇文章主要給大家介紹了關(guān)于Flutter UI如何使用Provide實(shí)現(xiàn)主題切換的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家學(xué)習(xí)或者使用Flutter具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2019-04-04

最新評(píng)論