效果圖:
![](https://img.laitimes.com/img/__Qf2AjLwojIjJCLyojI0JCLiAzNvwVZ2x2bzNXak9CX90TQNNkRrFlQKBTSvwFbslmZvwFMwQzLcVmepNHdu9mZvwFVywUNMZTY18CX052bm9CX31EVPVzaq5kMNpHW4Z0MMBjVtJWd0ckW65UbM5WOHJWa5kHT20ESjBjUIF2LcRHelR3LcJzLctmch1mclRXY39jM0YTOzgDMxAjMyUDM4EDMy8CX0Vmbu4GZzNmLn9Gbi1yZtl2Lc9CX6MHc0RHaiojIsJye.jpg)
布局:
<?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:layout_width="match_parent"
android:layout_height="match_parent"
tools:context=".MainActivity">
<android.support.v4.view.ViewPager
android:id="@+id/viewpager"
android:layout_width="match_parent"
android:layout_height="200dp" />
<LinearLayout
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_alignBottom="@id/viewpager"
android:background="#33000000"
android:orientation="vertical">
<TextView
android:id="@+id/tv_title"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:gravity="center"
android:text="廣告條"
android:textColor="@android:color/white"
android:textSize="18sp" />
<LinearLayout
android:id="@+id/point_group"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_gravity="center_horizontal"
android:orientation="horizontal"></LinearLayout>
</LinearLayout>
</RelativeLayout>
訓示點:
<?xml version="1.0" encoding="utf-8"?>
<shape xmlns:android="http://schemas.android.com/apk/res/android"
android:shape="oval">
<size
android:width="8dp"
android:height="8dp" />
<solid android:color="#aaFFFFFF" />
</shape>
<?xml version="1.0" encoding="utf-8"?>
<shape xmlns:android="http://schemas.android.com/apk/res/android"
android:shape="oval">
<size android:width="8dp" android:height="8dp" />
<solid android:color="#ff0000" />
</shape>
<?xml version="1.0" encoding="utf-8"?>
<selector xmlns:android="http://schemas.android.com/apk/res/android">
<item android:drawable="@drawable/point_focured" android:state_enabled="true" />
<item android:drawable="@drawable/point_normal" />
</selector>
activity:
package com.example.xyh.banner;
import android.os.Handler;
import android.os.Message;
import android.support.v4.view.ViewPager;
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.view.ViewGroup;
import android.widget.ImageView;
import android.widget.LinearLayout;
import android.widget.TextView;
import java.util.ArrayList;
import java.util.List;
/**
* 廣告輪播
*/
public class MainActivity extends AppCompatActivity {
private ViewPager mViewPager;
private TextView tvTitle;
private LinearLayout pointGroup;
private List<ImageView> list;
// 上一個頁面的位置
protected int lastPosition;
// 圖檔資源ID
private final int[] imageIds = {R.drawable.a, R.drawable.b, R.drawable.c,
R.drawable.d, R.drawable.e};
//圖檔标題集合
private final String[] title = {
"鞏俐不低俗,我就不能低俗",
"撲樹又回來啦!再唱經典老歌引萬人大合唱",
"揭秘北京電影如何更新",
"樂視網TV版大派送",
"熱血屌絲的反殺"
};
//判斷是否在自動滾動
private boolean isRunning = false;
private Handler mHandler = new Handler() {
@Override
public void handleMessage(Message msg) {
//讓viewPager 滑動到下一頁
mViewPager.setCurrentItem(mViewPager.getCurrentItem() + 1);
if (isRunning) {
// 繼續發送延時2 秒的消息, 形成類似遞歸的效果, 使廣告一直循環切換
mHandler.sendEmptyMessageDelayed(0, 3000);
}
}
};
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
findViews();
init();
initListener();
isRunning = true;
mHandler.sendEmptyMessageDelayed(0, 3000);
}
private void init() {
list = new ArrayList<>();
for (int i = 0; i < imageIds.length; i++) {
ImageView imageView = new ImageView(this);
imageView.setBackgroundResource(imageIds[i]);
list.add(imageView);
//動态添加訓示點
ImageView point = new ImageView(this);
point.setBackgroundResource(R.drawable.point_bg);
pointGroup.addView(point);
//布局參數
LinearLayout.LayoutParams params = new LinearLayout.LayoutParams(
ViewGroup.LayoutParams.WRAP_CONTENT,
ViewGroup.LayoutParams.WRAP_CONTENT);
if (i > 0) {
params.leftMargin = 20;
}
point.setLayoutParams(params); //設定布局參數
if (i == 0) {
point.setEnabled(true);
} else {
point.setEnabled(false);
}
}
MyPagerAdapter myPagerAdapter = new MyPagerAdapter(list);
mViewPager.setAdapter(myPagerAdapter);
tvTitle.setText(title[0]);
//把目前頁面設定為中間的,這樣左右都有很多頁面
mViewPager.setCurrentItem(Integer.MAX_VALUE / 2 - (Integer.MAX_VALUE / 2 % list.size()));
}
private void initListener() {
mViewPager.addOnPageChangeListener(new ViewPager.OnPageChangeListener() {
@Override
public void onPageScrolled(int position, float positionOffset, int positionOffsetPixels) {
}
@Override
public void onPageSelected(int position) {
position = position % list.size();
//設定訓示點狀态
pointGroup.getChildAt(position).setEnabled(true);
pointGroup.getChildAt(lastPosition).setEnabled(false);
lastPosition = position;
tvTitle.setText(title[position]);
}
@Override
public void onPageScrollStateChanged(int state) {
}
});
}
private void findViews() {
mViewPager = (ViewPager) findViewById(R.id.viewpager);
tvTitle = (TextView) findViewById(R.id.tv_title);
pointGroup = (LinearLayout) findViewById(R.id.point_group);
}
@Override
protected void onDestroy() {
super.onDestroy();
isRunning = false;
}
}
擴充卡:
package com.example.xyh.banner;
import android.support.v4.view.PagerAdapter;
import android.view.View;
import android.view.ViewGroup;
import android.widget.ImageView;
import java.util.List;
/**
* Created by xiaoyehai on 2018/5/22/022.
*/
public class MyPagerAdapter extends PagerAdapter {
private List<ImageView> list;
public MyPagerAdapter(List<ImageView> list) {
this.list = list;
}
@Override
public int getCount() {
//return list.size();
return Integer.MAX_VALUE;
}
@Override
public boolean isViewFromObject(View view, Object object) {
return view == object;
}
@Override
public Object instantiateItem(ViewGroup container, int position) {
ImageView imageView = list.get(position % list.size());
container.addView(imageView);
//實作按下停止輪播
imageView.setOnTouchListener(new View.OnTouchListener() {
@Override
public boolean onTouch(View view, MotionEvent motionEvent) {
switch (motionEvent.getAction()){
case MotionEvent.ACTION_DOWN:
handler.removeCallbacksAndMessages(null);
break;
case MotionEvent.ACTION_MOVE:
break;
case MotionEvent.ACTION_UP:
handler.removeCallbacksAndMessages(null);
handler.sendEmptyMessageDelayed(0,3000);
break;
}
return true;
}
});
return imageView;
}
@Override
public void destroyItem(ViewGroup container, int position, Object object) {
container.removeView((View) object);
object = null;
}
}
圖檔輪播也可以采用計時器的方式實作
第三方的圖檔輪播XBanner
第三方的圖檔輪播banner