今天就跟大家聊聊有关Android中怎么实现一个图片轮播列表,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。
我们提供的服务有:网站设计制作、成都网站建设、微信公众号开发、网站优化、网站认证、无极ssl等。为上1000+企事业单位解决了网站和推广的问题。提供周到的售前咨询和贴心的售后服务,是有科学管理、有技术的无极网站制作公司
布局文件代码:
主窗口代码:
public class IndexActivity extends AppCompatActivity implements View.OnClickListener{ private Context mContext; private List mImageList; private List mCandidateList; private ViewPagerAdapter mPagerAdapter; private CandidateListAdapter mListAdapter; @SuppressLint("HandlerLeak") private Handler handler = new Handler() { @Override public void handleMessage(Message msg) { //每次将当前的位置加1,也就是向右滑动一次 vp.setCurrentItem(vp.getCurrentItem() + 1); //递归无限循环调用 handler.sendEmptyMessageDelayed(0x123, 2000); } }; @Override protected void onCreate(@Nullable Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_index); ButterKnife.bind(this); initData(); initView(); intListener(); } //初始化数据源,固定写法 1.实例化容器 2.实例化适配器 3.设置适配器 private void initData() { mContext = this; mImageList = new ArrayList<>(); mCandidateList = new ArrayList<>(); mListAdapter = new CandidateListAdapter(mCandidateList); mPagerAdapter = new ViewPagerAdapter(mImageList); lvfsv.setAdapter(mListAdapter); vp.setAdapter(mPagerAdapter); getListData(10); getPagerData(); //间隔2秒发送一次信息 handler.sendEmptyMessageDelayed(0x123, 2000); } //生成ViewPager数据源 private void getPagerData() { mImageList.add(R.drawable.bm1); mImageList.add(R.drawable.bm2); mImageList.add(R.drawable.bm3); mImageList.add(R.drawable.bm4); mImageList.add(R.drawable.bm5); mImageList.add(R.drawable.bm6); mPagerAdapter.notifyDataSetChanged(); //初始的位置在正中间 vp.setCurrentItem(mPagerAdapter.getCount() / 2); } //生成ListView数据源 private void getListData(int num) { for (int i = 0; i < num; i++) { Candidate candidate = new Candidate(); candidate.setName("姓名:尼尔斯·亨利克·戴维·玻尔"); candidate.setInfo("职业:学者,物理学家,足球运动员"); candidate.setTrait("成就:哥本哈根学派的创始人,1922年获得诺贝尔物理学奖"); mCandidateList.add(candidate); } mListAdapter.notifyDataSetChanged(); } private void initView() { tvTitleMiddle.setText("轮播列表"); //手动设置ScrollView的位置 scrollView.smoothScrollTo(0, 0); } //初始化监听 private void intListener() { mPagerAdapter.setmCallback((v, position) -> { Toast.makeText(mContext, "position: " + position, Toast.LENGTH_SHORT).show(); }); lvfsv.setOnItemClickListener((parent, view, position, id) -> { Toast.makeText(mContext, "position: " + position, Toast.LENGTH_SHORT).show(); }); for (int i = 0; i < 4; i++) { ivs.getChildAt(i).setOnClickListener(this); } } @Override public void onClick(View v) { switch (v.getId()){ case R.id.iv1: case R.id.iv2: case R.id.iv3: case R.id.iv4: Toast.makeText(mContext, "此处跳转", Toast.LENGTH_SHORT).show(); } }}
ListView需要覆盖onMeasure方法,代码如下:
public class ListViewForScrollView extends ListView { public ListViewForScrollView(Context context) { super(context); } public ListViewForScrollView(Context context, AttributeSet attrs) { super(context, attrs); } public ListViewForScrollView(Context context, AttributeSet attrs, int defStyle) { super(context, attrs, defStyle); } @Override /** * 重写该方法,达到使ListView适应ScrollView的效果 */ protected void onMeasure(int widthMeasureSpec, int heightMeasureSpec) { int expandSpec = MeasureSpec.makeMeasureSpec(Integer.MAX_VALUE >> 2, MeasureSpec.AT_MOST); super.onMeasure(widthMeasureSpec, expandSpec); }}
ViewPager适配器代码:
public class ViewPagerAdapter extends PagerAdapter implements View.OnClickListener { //图片的资源id列表 private List mList; private Callback mCallback; public ViewPagerAdapter(List mList) { this.mList = mList; } public void setmCallback(Callback mCallback) { this.mCallback = mCallback; } public interface Callback { void onClick(View v, int position); } @Override //将适配器中的数据设为无穷大 public int getCount() { return Integer.MAX_VALUE; } @Override //固定写法,不覆盖会报错 public void destroyItem(@NonNull ViewGroup container, int position, @NonNull Object object) { container.removeView((View) object); } @Override //固定写法 public boolean isViewFromObject(@NonNull View view, @NonNull Object object) { return view == object; } @NonNull @Override public Object instantiateItem(@NonNull ViewGroup container, int position) { LayoutInflater inflater = LayoutInflater.from(container.getContext()); ImageView imageView = (ImageView) inflater.inflate(R.layout.item_image_pager, null); //将position转换成余数 int realPosition = position % mList.size(); imageView.setImageResource(mList.get(realPosition)); imageView.setOnClickListener(this); //tag放跳转需要的数据 imageView.setTag(realPosition); //将实例加入父控件 container.addView(imageView); return imageView; } @Override //使用接口将position回传 public void onClick(View v) { mCallback.onClick(v, (int) v.getTag()); }}
看完上述内容,你们对Android中怎么实现一个图片轮播列表有进一步的了解吗?如果还想了解更多知识或者相关内容,请关注创新互联行业资讯频道,感谢大家的支持。
本文标题:Android中怎么实现一个图片轮播列表
网站路径:
http://njwzjz.com/article/piosdi.html