热门标签 | HotTags
当前位置:  开发笔记 > 运维 > 正文

Android自定义控件之广告条滚动效果

这篇文章主要为大家详细介绍了Android自定义控件之广告条滚动效果,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

在一些电子商务网站上经常能够看到一些滚动的广告条,许多软件在首次使用时也有类似的广告条,如图:

这里写图片描述

其实在github上有实现这种效果的控件,不过这东西做起来也是很简单,我们今天就来看看该怎么做。

先来看看布局文件:



  

  

    
    
  



布局文件最上边是一个Viewpager,使用viewpager来实现图片的滚动效果,viewpager下边是一个linearlayout,这个布局文件中有两个东西,一个是textview,这是用来显示下边那一行字的,还有一个linearlayout,这是用来显示字下边的小点,小点的个数我们要根据图片的数量动态添加,所以现在先空着。

MainActivity.java

public class MainActivity extends Activity {

  private ViewPager mViewPager;
  // 图片都存放在这里
  private List imageViewlist;
  private ImageView iv;
  private TextView imgDes;
  // 线程开关,当activity销毁后,线程也应该停止运行
  private boolean isStop = false;
  private int previousPoint = 0;
  // 存放小点的布局文件
  private LinearLayout layoutPGroup;
  private String[] imageDescription = { "淮左名都,竹西佳处,解鞍少驻初程。", "过春风十里。尽荠麦青青。",
      "自胡马窥江去后,废池乔木,犹厌言兵。", "渐黄昏,清角吹寒。都在空城。", "杜郎俊赏,算而今、重到须惊。" };

  @Override
  protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_main);
    // 初始化
    init();
    //设置图片自动滚动
    new Thread(new Runnable() {

      @Override
      public void run() {
        //如果activity未销毁则一直执行
        while (!isStop) {
          //先休息5秒钟
          SystemClock.sleep(5000);
          //以下代码发送到主线程中执行
          runOnUiThread(new Runnable() {

            @Override
            public void run() {
              mViewPager.setCurrentItem(mViewPager
                  .getCurrentItem() + 1);
            }
          });
        }
      }
    }).start();
  }

  private void init() {
    mViewPager = (ViewPager) this.findViewById(R.id.viewpager);
    layoutPGroup = (LinearLayout) this.findViewById(R.id.show_pointer);
    imgDes = (TextView) this.findViewById(R.id.image_description);
    imageViewlist = new ArrayList();

    // 先拿到图片id
    int[] ivIDs = new int[] { R.drawable.a, R.drawable.b, R.drawable.c,
        R.drawable.d, R.drawable.e };
    // 遍历图片id
    for (int id : ivIDs) {
      // 构造新的图片对象,并根据id给图片设置背景
      iv = new ImageView(this);
      iv.setBackgroundResource(id);
      // 所有的图片存放在imageViewlist中
      imageViewlist.add(iv);

      // 构造小点
      View v = new View(this);
      // 设置小点的宽和高
      LayoutParams params = new LayoutParams(8, 8);
      // 设置小点的左边距
      params.leftMargin = 12;
      v.setLayoutParams(params);
      // 设置小点是否可用,默认都不可用,当不可用时,小点是透明的,否则是白色的
      v.setEnabled(false);
      // 设置小点的背景,这个背景是使用xml文件画的一个小圆点
      v.setBackgroundResource(R.drawable.pointer_selector);
      // 把小点添加到它的布局文件中
      layoutPGroup.addView(v);
    }
    // 计算应用打开时显示的第一项 Integer.MAX_VALUE /2 - 3=0
    int index = Integer.MAX_VALUE / 2 - 3;
    // 给mViewPager设置数据
    mViewPager.setAdapter(new MyPagerAdapter());
    // 给mViewPager设置页面滑动事件
    mViewPager.setOnPageChangeListener(new MyOnPageChangeListener());

    // 设置应用打开时显示的第一项,index的值为0
    // 使用这种方式得到的0,和直接写0有什么区别呢?
    // 直接写0,应用打开后不能直接向右滑动,因为viewpager中存image位置不能为负值,只能先向左滑动
    // 这种方式得到的0,可以实现应用一打开,就可以向右滑动
    mViewPager.setCurrentItem(index);
  }

  private class MyOnPageChangeListener implements OnPageChangeListener {

    // 开始
    @Override
    public void onPageScrollStateChanged(int arg0) {
    }

    // 正在进行时
    @Override
    public void onPageScrolled(int arg0, float arg1, int arg2) {
    }

    // 结束
    @Override
    public void onPageSelected(int position) {
      // 当页面滑动结束时,先对页面位置取模
      position = position % imageViewlist.size();
      // 设置textview的文本内容
      imgDes.setText(imageDescription[position]);
      // 将上一个点的可用性设置为false
      layoutPGroup.getChildAt(previousPoint).setEnabled(false);
      // 把当前点的可用性设置为true
      layoutPGroup.getChildAt(position).setEnabled(true);
      // 把当前位置值赋值给previousPoint
      previousPoint = position;
    }
  }

  private class MyPagerAdapter extends PagerAdapter {

    /**
     * 返回图片总数,Integer.MAX_VALUE的值为 2147483647这个数有21亿,也就是说我们的viewpager
     * 理论上在每次使用应用的时候可以滑动21亿次,当然,实际上是没人要去这么做的,我们这样做是为了实现实现viewpager循环滑动的效果
     * 即当滑动到viewpager的最后一页时,继续滑动就可以回到第一页
     * 
     */
    @Override
    public int getCount() {
      return Integer.MAX_VALUE;
    }

    @Override
    public boolean isViewFromObject(View arg0, Object arg1) {
      return arg0 == arg1;
    }

    // 当某一页滑出去的时候,将其销毁
    @Override
    public void destroyItem(ViewGroup container, int position, Object object) {
      container.removeView(imageViewlist.get(position
          % imageViewlist.size()));
    }

    // 向容器中添加图片,由于我们要实现循环滑动的效果,所以要对position取模
    @Override
    public Object instantiateItem(ViewGroup container, int position) {
      container
          .addView(imageViewlist.get(position % imageViewlist.size()));
      return imageViewlist.get(position % imageViewlist.size());
    }
  }

  // 当activity销毁时,让线程停止
  @Override
  protected void onDestroy() {
    isStop = true;
    super.onDestroy();
  }

}

代码中的注释已经说的很详细了,我就不再赘述了。

未选中的小圆点pointer_disable.xml:

<&#63;xml version="1.0" encoding="utf-8"&#63;>


  
  

  
  



选中时的小圆点pointer_focus.xml:

<&#63;xml version="1.0" encoding="utf-8"&#63;>


  

  



小圆点的选择器:

<&#63;xml version="1.0" encoding="utf-8"&#63;>

  
  
  
  


源码下载:http://xiazai.jb51.net/201606/yuanma/Androidmove(jb51.net).rar

原文链接:http://blog.csdn.net/u012702547/article/details/45845613

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。


推荐阅读
  • Java验证码——kaptcha的使用配置及样式
    本文介绍了如何使用kaptcha库来实现Java验证码的配置和样式设置,包括pom.xml的依赖配置和web.xml中servlet的配置。 ... [详细]
  • XML介绍与使用的概述及标签规则
    本文介绍了XML的基本概念和用途,包括XML的可扩展性和标签的自定义特性。同时还详细解释了XML标签的规则,包括标签的尖括号和合法标识符的组成,标签必须成对出现的原则以及特殊标签的使用方法。通过本文的阅读,读者可以对XML的基本知识有一个全面的了解。 ... [详细]
  • 本文介绍了Android 7的学习笔记总结,包括最新的移动架构视频、大厂安卓面试真题和项目实战源码讲义。同时还分享了开源的完整内容,并提醒读者在使用FileProvider适配时要注意不同模块的AndroidManfiest.xml中配置的xml文件名必须不同,否则会出现问题。 ... [详细]
  • 在Docker中,将主机目录挂载到容器中作为volume使用时,常常会遇到文件权限问题。这是因为容器内外的UID不同所导致的。本文介绍了解决这个问题的方法,包括使用gosu和suexec工具以及在Dockerfile中配置volume的权限。通过这些方法,可以避免在使用Docker时出现无写权限的情况。 ... [详细]
  • YOLOv7基于自己的数据集从零构建模型完整训练、推理计算超详细教程
    本文介绍了关于人工智能、神经网络和深度学习的知识点,并提供了YOLOv7基于自己的数据集从零构建模型完整训练、推理计算的详细教程。文章还提到了郑州最低生活保障的话题。对于从事目标检测任务的人来说,YOLO是一个熟悉的模型。文章还提到了yolov4和yolov6的相关内容,以及选择模型的优化思路。 ... [详细]
  • 本文介绍了使用kotlin实现动画效果的方法,包括上下移动、放大缩小、旋转等功能。通过代码示例演示了如何使用ObjectAnimator和AnimatorSet来实现动画效果,并提供了实现抖动效果的代码。同时还介绍了如何使用translationY和translationX来实现上下和左右移动的效果。最后还提供了一个anim_small.xml文件的代码示例,可以用来实现放大缩小的效果。 ... [详细]
  • 云原生边缘计算之KubeEdge简介及功能特点
    本文介绍了云原生边缘计算中的KubeEdge系统,该系统是一个开源系统,用于将容器化应用程序编排功能扩展到Edge的主机。它基于Kubernetes构建,并为网络应用程序提供基础架构支持。同时,KubeEdge具有离线模式、基于Kubernetes的节点、群集、应用程序和设备管理、资源优化等特点。此外,KubeEdge还支持跨平台工作,在私有、公共和混合云中都可以运行。同时,KubeEdge还提供数据管理和数据分析管道引擎的支持。最后,本文还介绍了KubeEdge系统生成证书的方法。 ... [详细]
  • android listview OnItemClickListener失效原因
    最近在做listview时发现OnItemClickListener失效的问题,经过查找发现是因为button的原因。不仅listitem中存在button会影响OnItemClickListener事件的失效,还会导致单击后listview每个item的背景改变,使得item中的所有有关焦点的事件都失效。本文给出了一个范例来说明这种情况,并提供了解决方法。 ... [详细]
  • 本文讨论了Alink回归预测的不完善问题,指出目前主要针对Python做案例,对其他语言支持不足。同时介绍了pom.xml文件的基本结构和使用方法,以及Maven的相关知识。最后,对Alink回归预测的未来发展提出了期待。 ... [详细]
  • 本文讲述了如何通过代码在Android中更改Recycler视图项的背景颜色。通过在onBindViewHolder方法中设置条件判断,可以实现根据条件改变背景颜色的效果。同时,还介绍了如何修改底部边框颜色以及提供了RecyclerView Fragment layout.xml和项目布局文件的示例代码。 ... [详细]
  • 在说Hibernate映射前,我们先来了解下对象关系映射ORM。ORM的实现思想就是将关系数据库中表的数据映射成对象,以对象的形式展现。这样开发人员就可以把对数据库的操作转化为对 ... [详细]
  • 本文介绍了在SpringBoot中集成thymeleaf前端模版的配置步骤,包括在application.properties配置文件中添加thymeleaf的配置信息,引入thymeleaf的jar包,以及创建PageController并添加index方法。 ... [详细]
  • Google Play推出全新的应用内评价API,帮助开发者获取更多优质用户反馈。用户每天在Google Play上发表数百万条评论,这有助于开发者了解用户喜好和改进需求。开发者可以选择在适当的时间请求用户撰写评论,以获得全面而有用的反馈。全新应用内评价功能让用户无需返回应用详情页面即可发表评论,提升用户体验。 ... [详细]
  • 自动轮播,反转播放的ViewPagerAdapter的使用方法和效果展示
    本文介绍了如何使用自动轮播、反转播放的ViewPagerAdapter,并展示了其效果。该ViewPagerAdapter支持无限循环、触摸暂停、切换缩放等功能。同时提供了使用GIF.gif的示例和github地址。通过LoopFragmentPagerAdapter类的getActualCount、getActualItem和getActualPagerTitle方法可以实现自定义的循环效果和标题展示。 ... [详细]
  • 标题: ... [详细]
author-avatar
蓝月亮乐悠悠
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有