广告
返回顶部
首页 > 资讯 > 移动开发 >Android实现轮播效果的两种方法
  • 569
分享到

Android实现轮播效果的两种方法

方法轮播Android 2022-06-06 04:06:25 569人浏览 独家记忆
摘要

实现轮播效果有2种方法: (1)使用ViewPager+ImageView,通过Handler进行间隔发送消息,实现自动轮播效果 xml代码: <Android

实现轮播效果有2种方法:

(1)使用ViewPager+ImageView,通过Handler进行间隔发送消息,实现自动轮播效果

xml代码:


<Android.support.v4.view.ViewPager
    android:id="@+id/fragment_viewPager"
    android:layout_width="match_parent"
    android:layout_height="200dp" />

 private Handler handler=new Handler(){
    @Override
    public void handleMessage(Message msg) {
      super.handleMessage(msg);
      list= (List<BannerBean>) msg.obj;
      //进行下载图片
      for (int i = 0; i < 3; i++) {
        Picasso.with(getActivity()).load(list.get(i).getImgs()).resize(640,400).into(imgs.get(i));
      }
      //展示图片
      MyAdapter adapter=new MyAdapter();
      viewPager.setAdapter(adapter);
    }
  };
  private Handler handler2=new Handler(){
    @Override
    public void handleMessage(Message msg) {
      super.handleMessage(msg);
      //获取当前viewPager的位置
      int pos=viewPager.getCurrentItem();
      //如果是最后一张图片就进行设置为第一张,实现循环
      if(pos==imgs.size()-1){
        pos=0;
       //否则进行下一张图片展示
      }else{
        pos++;
      }
      //设置viewPager的位置
      viewPager.setCurrentItem(pos);
      //定时发送消息
      handler2.sendEmptyMessageDelayed(1,2000);
    }
  };
   @Override
  public View onCreateView(LayoutInflater inflater, ViewGroup container,
               Bundle savedInstanceState) {
    View view=inflater.inflate(R.layout.fragment_recreation, container, false);
    initview(view);
    load();
    //发送消息给handler2,实现自动轮播
    handler2.sendEmptyMessageDelayed(1,2000);
    initListener();
    return view;
  }
   private void load() {
    //下载图片地址
    new Thread(){
      @Override
      public void run() {
        super.run();
        String JSON= Utils.getjsonFromNet(ContentUrls.headLine_head+0);
        if(!TextUtils.isEmpty(json)){
          List<BannerBean>data= ParserBanner.getData(json);
          Message msg=new Message();
          msg.obj=data;
          handler.sendMessage(msg);
        }
      }
    }.start();
    data=new ArrayList<>();
    headlineAdapter=new HeadlineAdapter(data,getActivity());
    lv.setAdapter(headlineAdapter);
    new MyAsyncTask(data,headlineAdapter).execute(ContentUrls.headLine_head+num);
  }
  private void initview(View view) {
    lv = ((ListView) view.findViewById(R.id.lv));
    headerView = LayoutInflater.from(getActivity()).inflate(R.layout.header_layout,null,false);
    viewPager = ((ViewPager)headerView.findViewById(R.id.fragment_viewPager));
    lv.addHeaderView(headerView);
    list=new ArrayList<>();
    imgs=new ArrayList<>();
    for (int i = 0; i < 3; i++) {
      ImageView iv=new ImageView(getActivity());
      imgs.add(iv);
    }
  }

adapter:


 class MyAdapter extends PagerAdapter{
    @Override
    public int getCount() {
      return imgs.size();
    }
    @Override
    public boolean isViewFromObject(View view, Object object) {
      return view==object;
    }
    @Override
    public Object instantiateItem(ViewGroup container, int position) {
      container.addView(imgs.get(position));
      return imgs.get(position);
    }
    @Override
    public void destroyItem(ViewGroup container, int position, Object object) {
//      super.destroyItem(container, position, object);
      container.removeView(imgs.get(position));
    }
  }

(2)使用SliderLayout第三方进行实现轮播

添加依赖:


  compile 'com.squareup.picasso:picasso:2.5.2'
  compile 'com.daimajia.slider:library:1.1.5@aar'
  compile 'com.nineoldandroids:library:2.4.0'

xml代码:


<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="Http://schemas.android.com/apk/res/android"
  android:layout_width="match_parent"
  android:layout_height="match_parent">
  <com.daimajia.slider.library.SliderLayout
    android:id="@+id/header_slider"
    android:layout_width="match_parent"
    android:layout_height="160dp"></com.daimajia.slider.library.SliderLayout>
</LinearLayout>

Java代码:


private ListView lv;
  private String[] title={"烟","超标","标准","审车合格"};
  private int[] imgs={R.mipmap.a,R.mipmap.b,R.mipmap.c,R.mipmap.d};
  private SliderLayout slider;
 @Override
  public View onCreateView(LayoutInflater inflater, ViewGroup container,
               Bundle savedInstanceState) {
    View view=inflater.inflate(R.layout.fragment_home_page, container, false);
    lv = ((ListView) view.findViewById(R.id.homePage_lv));
    View headerView=LayoutInflater.from(getActivity()).inflate(R.layout.header_layout,null,false);
    slider = ((SliderLayout) headerView.findViewById(R.id.header_slider));
    lv.addHeaderView(headerView);
    initSlider();
    initData();
    return view;
  }
  private void initSlider() {
    for (int i = 0; i < 4; i++) {
      TextSliderView textSlider=new TextSliderView(getActivity());
      textSlider.image(imgs[i]).description(title[i]);
      slider.addSlider(textSlider);
      textSlider.setOnSliderClickListener(new BaseSliderView.OnSliderClickListener() {
        @Override
        public void onSliderClick(BaseSliderView slider) {
          Toast.makeText(getActivity(),slider.getDescription(),Toast.LENGTH_SHORT).show();
        }
      });
    }
  }
您可能感兴趣的文章:Android实现图片轮播效果的两种方法Android实现图片轮播效果Android 使用ViewPager自动滚动循环轮播效果Android实现Banner界面广告图片循环轮播(包括实现手动滑动循环)Android实现图片文字轮播特效Android实现广告图片轮播效果Android自定义控件实现简单的轮播图控件Android实现图片轮播切换实例代码Android自动播放Banner图片轮播效果Android ViewPager实现图片轮播效果


--结束END--

本文标题: Android实现轮播效果的两种方法

本文链接: https://www.lsjlt.com/news/22418.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • Android实现轮播效果的两种方法
    实现轮播效果有2种方法: (1)使用ViewPager+ImageView,通过Handler进行间隔发送消息,实现自动轮播效果 xml代码: <android...
    99+
    2022-06-06
    方法 轮播 Android
  • Android实现图片轮播效果的两种方法
    大家在使用APP的过程中,经常会看到上部banner图片轮播的效果,那么今天我们就一起来学习一下,android中图片轮询的几种实现方法: 第一种:使用动画的方法实现:(代码繁...
    99+
    2022-06-06
    方法 图片 轮播 Android
  • Android实现轮播图效果
    本文实例为大家分享了Android实现轮播图效果的具体代码,供大家参考,具体内容如下 1.代码放在LinearLayout中, <com.jude.rollviewpage...
    99+
    2022-11-12
  • android viewpager实现轮播效果
    本文是基于ViewPager实现的无限自动轮播banner,供大家参考,具体内容如下 分为四步去实现: 第一步是有限手动轮播; 第二步是无限轮播; 第三步是自动轮播; 第四步是指示...
    99+
    2022-11-13
  • JS实现轮播图效果的3种简单方法
    本文实例为大家分享了3种方法实现JS轮播图效果的具体代码,供大家参考,具体内容如下 Js实现轮播图01 实现思路 这可能是轮播图最简单点的实现之一,通过更改图片的src来实现该效果,...
    99+
    2022-11-12
  • Android使用Recyclerview实现图片轮播效果的方法
    这篇文章将为大家详细讲解有关Android使用Recyclerview实现图片轮播效果的方法,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。效果图:思路:准备m张图片使用Recyclerview实现,返回无...
    99+
    2023-05-30
    android recyclerview 滚动效果
  • Android ViewPager实现轮播图效果
    先上一张效果图: 说到ViewPager实现轮播图效果,那么肯定会用到PagerAdapter,下面先介绍下这个类。 PagerAdapter简介 PagerAdapter是...
    99+
    2022-06-06
    轮播图 viewpager 轮播 Android
  • Android实现图片轮播效果
    本文实例讲述了JaAndroid实现图片轮播效果代码,分享给大家供大家参考。具体如下: 运行效果截图如下: 具体代码如下: 首先看下一下布局文件: <Relative...
    99+
    2022-06-06
    图片 轮播 Android
  • Android实现视图轮播效果
    最近接手了一个需求,要求实现,叮咚买菜。 秒杀位置的轮播 拆解 通过观察发现其实还是挺简单,大致分为 1、商品图片的上下轮播 2、价格布局渐隐渐现 在android上实现布局轮播,...
    99+
    2022-11-12
  • android如何实现banner轮播图无限轮播效果
    小编给大家分享一下android如何实现banner轮播图无限轮播效果,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧!具体内容如下效果展示第一步(权限配置)<uses-permission android:n...
    99+
    2023-05-30
    android banner
  • android使用ViewPager实现轮播效果
    ViewPager:一个可以实现视图左右滑动切换的控件。 ViewPager的基本使用: ViewPager的视图需要通过PagerAdapter来实现显示。 Pager...
    99+
    2022-06-06
    viewpager 轮播 Android
  • Android ViewPager实现图片轮播效果
    在app中图片的轮播显示可以说是非常常见的实现效果了,其实现原理不过是利用ViewPager,然后利用handler每隔一定的时间将ViewPager的currentItem设...
    99+
    2022-06-06
    图片 viewpager 轮播 Android
  • android viewpager怎么实现轮播效果
    本篇内容介绍了“android viewpager怎么实现轮播效果”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!分为四步去实现:第...
    99+
    2023-07-02
  • Android实现图片叠加效果的两种方法
    本文实例讲述了Android实现图片叠加效果的两种方法。分享给大家供大家参考,具体如下: 效果图: 第一种: 第二种: 第一种是通过canvas画出来的效果: publi...
    99+
    2022-06-06
    方法 图片 Android
  • Android UI实现广告Banner轮播效果
    本篇博客要分享的一个效果是实现广告Banner轮播效果,这个效果也比较常见,一些视频类应用就经常有,就拿360影视大全来举例吧:   用红框框住的那个效果就是小巫今天...
    99+
    2022-06-06
    Android
  • Android实现广告图片轮播效果
    本文实例介绍了Android广告轮播图效果实现方法,分享给大家供大家参考,具体内容如下 首先看下一下布局文件: <RelativeLayout xmlns:andro...
    99+
    2022-06-06
    图片 广告 轮播 Android
  • JS实现轮播图效果的方法有哪些
    这篇文章主要讲解了“JS实现轮播图效果的方法有哪些”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“JS实现轮播图效果的方法有哪些”吧!Js实现轮播图01实现思路这可能是轮播图最简单点的实现之一...
    99+
    2023-06-25
  • Android实现循环轮播跑马灯的效果
    目录先看效果池化思路创造工厂轮询切换动画监听对外能力完整代码先看效果 支持暂停,恢复,view自定义和池化回收复用。使用上,只需要引入xml,并绑定factory即可,内部会在a...
    99+
    2023-05-18
    Android实现循环轮播跑马灯效果 Android实现跑马灯 Android跑马灯
  • Android实现轮播图无限循环效果
    本文实例为大家分享了Android轮播图无限循环的具体代码,供大家参考,具体内容如下 实现无限循环 在getCount()方法中,返回一个很大的值,Integer.MAX_VA...
    99+
    2022-06-06
    轮播图 循环 轮播 Android
  • android控件Banner实现简单轮播图效果
    本文实例为大家分享了android控件Banner实现简单轮播图效果的具体代码,供大家参考,具体内容如下 实现这个轮播图是在Fragment里实现的,所以要想实现,首先要创建Frag...
    99+
    2022-11-12
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作