Android BannerView通用封装详解

作者:Gentleman1995 时间:2021-11-16 18:45:41 

之前封装过一个,但总觉得不够优雅,就有了这个通用封装,很简洁,不知道够不够优雅,不过原来那个有跟随指示器和丝滑滑动效果,感兴趣可以看一下。

封装过程

1、自定义属性

selectPoint:选中指示器图标
normalPoint:未选中指示器图标
pointWidth:图标宽度
switchTime:轮播间隔事件
location:指示器位置,下中或下右


<declare-styleable name="NewBannerView">
   <attr name="selectPoint" format="reference" />
   <attr name="normalPoint" format="reference" />
   <attr name="pointWidth" format="dimension" />
   <attr name="switchTime" format="integer" />
   <attr name="location">
     <enum name="CENTER" value="0" />
     <enum name="RIGHT" value="1" />
   </attr>
 </declare-styleable>

2、初始化View
初始化ViewPager和指示器组合View

3、绑定数据源
通过setImageData设置轮播图数据源

4、绑定点击事件
通过OnPageClickListener绑定点击事件

5、开启关闭轮播
start和stop方法开启和关闭轮播

用法

xml中


<com.goldou.lovesee.view.NewBannerView
   android:id="@+id/bannerView"
   android:layout_width="match_parent"
   app:selectPoint="@drawable/red_point"
   app:normalPoint="@drawable/gray_point"
   app:switchTime="4000"
   app:location="RIGHT"
   android:layout_height="200dp" />

activity中


int[] imageList = {R.drawable.me_top, R.drawable.me_top, R.drawable.me_top, R.drawable.me_top};
   NewBannerView bannerView = view.findViewById(R.id.bannerView);
   bannerView.setImageData(imageList);
   bannerView.start();
   bannerView.setOnPageClickListener(new NewBannerView.OnPageClickListener() {
     @Override
     public void onPageClick(int position) {
       Toast.makeText(getActivity(), position + "", Toast.LENGTH_SHORT).show();
     }
   });

BannerView


public class NewBannerView extends RelativeLayout implements View.OnClickListener {
 private Context context;
 private int selectPoint, normalPoint;
 private float pointWidth = 7;
 private int location;
 private int CENTER = 0, RIGHT = 1;
 private int lastPosition = 0;
 private ViewPager viewPager;
 private int switchTime = 5000;
 private int[] images;
 private OnPageClickListener onPageClickListener;

private Handler handler = new Handler(new Handler.Callback() {
   @Override
   public boolean handleMessage(Message msg) {
     if (msg.what == 101) {
       viewPager.setCurrentItem(viewPager.getCurrentItem() + 1);
       start();
     }
     return false;
   }
 });

public NewBannerView(Context context) {
   this(context, null);
 }

public NewBannerView(Context context, AttributeSet attrs) {
   this(context, attrs, 0);
 }

public NewBannerView(Context context, AttributeSet attrs, int defStyleAttr) {
   super(context, attrs, defStyleAttr);
   this.context = context;
   initAttr(attrs);
 }

private void initAttr(AttributeSet attrs) {
   TypedArray array = context.obtainStyledAttributes(attrs, R.styleable.NewBannerView);
   selectPoint = array.getResourceId(R.styleable.NewBannerView_selectPoint, R.mipmap.ic_launcher_round);
   normalPoint = array.getResourceId(R.styleable.NewBannerView_normalPoint, R.mipmap.ic_launcher_round);
   pointWidth = array.getDimension(R.styleable.NewBannerView_pointWidth, pointWidth);
   location = array.getInteger(R.styleable.NewBannerView_location, RIGHT);
   switchTime = array.getInteger(R.styleable.NewBannerView_switchTime, switchTime);
   array.recycle();
 }

public void setImageData(final int[] images) {
   this.images = images;
   final LinearLayout ll_point = new LinearLayout(context);
   LayoutParams layoutParams = new LayoutParams(LayoutParams.WRAP_CONTENT, LayoutParams.WRAP_CONTENT);
   layoutParams.addRule(ALIGN_PARENT_BOTTOM, RelativeLayout.TRUE);
   layoutParams.bottomMargin = 20;
   if (location == CENTER) {
     layoutParams.addRule(CENTER_HORIZONTAL, RelativeLayout.TRUE);
   } else {
     layoutParams.addRule(ALIGN_PARENT_RIGHT, RelativeLayout.TRUE);
     layoutParams.rightMargin = 20;
   }
   LinearLayout.LayoutParams params1 = new LinearLayout.LayoutParams(UIUtil.dip2px(pointWidth), UIUtil.dip2px(pointWidth));
   LinearLayout.LayoutParams params2 = new LinearLayout.LayoutParams(UIUtil.dip2px(pointWidth), UIUtil.dip2px(pointWidth));
   params1.leftMargin = 0;
   params2.leftMargin = UIUtil.dip2px(pointWidth);
   for (int i = 0; i < images.length; i++) {
     ImageView point = new ImageView(context);
     if (i == 0) {
       point.setBackgroundResource(selectPoint);
       point.setLayoutParams(params1);
     } else {
       point.setBackgroundResource(normalPoint);
       point.setLayoutParams(params2);
     }
     ll_point.addView(point);
   }

viewPager = new ViewPager(context);
   viewPager.setAdapter(new BannerAdapter());
   viewPager.addOnPageChangeListener(new ViewPager.OnPageChangeListener() {
     @Override
     public void onPageScrolled(int position, float positionOffset, int positionOffsetPixels) {

}

@Override
     public void onPageSelected(int position) {
       position = position % images.length;
       if (lastPosition == position) {
         return;
       }
       ll_point.getChildAt(position).setBackgroundResource(selectPoint);
       ll_point.getChildAt(lastPosition).setBackgroundResource(normalPoint);
       lastPosition = position;
     }

@Override
     public void onPageScrollStateChanged(int state) {

}
   });
   LayoutParams layoutParams1 = new LayoutParams(LayoutParams.MATCH_PARENT, LayoutParams.MATCH_PARENT);
   addView(viewPager, layoutParams1);
   addView(ll_point, layoutParams);
 }

public void start() {
   handler.sendEmptyMessageDelayed(101, switchTime);
 }

public void stop() {
   handler.removeCallbacksAndMessages(null);
 }

private int getCurrentItem() {
   return viewPager.getCurrentItem() % images.length;
 }

@Override
 public void onClick(View view) {
   onPageClickListener.onPageClick(getCurrentItem());
 }

public interface OnPageClickListener {
   void onPageClick(int position);
 }

public void setOnPageClickListener(OnPageClickListener onPageClickListener) {
   this.onPageClickListener = onPageClickListener;
 }

private class BannerAdapter extends PagerAdapter {

@Override
   public int getCount() {
     return Integer.MAX_VALUE;
   }

@Override
   public boolean isViewFromObject(View view, Object object) {
     return view == object;
   }

@Override
   public Object instantiateItem(ViewGroup container, int position) {
     position = position % images.length;
     ImageView imageView = new ImageView(context);
     imageView.setImageResource(images[position]);
     imageView.setScaleType(ImageView.ScaleType.FIT_XY);
     imageView.setOnClickListener(NewBannerView.this);
     container.addView(imageView);
     return imageView;
   }

@Override
   public void destroyItem(ViewGroup container, int position, Object object) {
     container.removeView((View) object);
   }
 }
}

来源:https://www.jianshu.com/p/594c95c98f62

标签:Android,BannerView
0
投稿

猜你喜欢

  • 完美解决java读取大文件内存溢出的问题

    2023-07-31 17:53:17
  • C#使用StopWatch获取程序毫秒级执行时间的方法

    2023-12-21 02:44:06
  • Android中判断网络连接是否可用及监控网络状态

    2022-09-07 05:24:25
  • 浅谈Servlet开发技术基础

    2023-01-17 04:03:15
  • Java实现导出word表格的示例详解

    2023-01-02 21:36:48
  • 为什么阿里巴巴要求日期格式化时必须有使用y表示年

    2023-11-02 20:08:58
  • Android逆向入门之常见Davlik字节码解析

    2023-09-13 02:53:10
  • OpenCV + MFC实现简单人脸识别

    2023-02-24 06:15:55
  • Java lambda表达式与泛型整理总结

    2021-07-15 19:57:14
  • android水平循环滚动控件使用详解

    2023-07-24 15:25:34
  • Android设置Activity背景为透明style的简单方法(必看)

    2021-08-13 14:20:18
  • java代码执行字符串中的逻辑运算方法

    2023-11-29 12:13:06
  • Mybatis 如何开启控制台打印sql语句

    2023-08-02 02:01:53
  • C#中的值传递和引用传递详细解析

    2022-03-20 20:11:02
  • 详解java中产生死锁的原因及如何避免

    2022-04-22 00:36:14
  • Java异步处理机制实例详解

    2022-05-12 01:39:37
  • 一文详解Java中流程控制语句

    2023-11-26 11:39:49
  • Android打开GPS导航并获取位置信息返回null解决方案

    2021-08-31 09:21:19
  • Java利用蒙特卡洛方法求解圆周率π值

    2023-04-10 14:10:28
  • 聊聊关于Java方法重写的反思

    2022-10-26 00:36:12
  • asp之家 软件编程 m.aspxhome.com