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

Android自定义viewgroup使用adapter适配数据(6)

这篇文章主要为大家详细介绍了Android自定义viewgroup,使用adapter适配数据,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

在自定义viewgroup(5):https://www.jb51.net/article/100639.htm的基础上,添加使用adapter来适配数据,这样更加的方便,这里只是使用adapter适配数据,不能更新。

package com.example.libingyuan.horizontallistview.ScrollViewGroup;

import android.content.Context;
import android.util.AttributeSet;
import android.util.DisplayMetrics;
import android.util.Log;
import android.view.GestureDetector;
import android.view.MotionEvent;
import android.view.View;
import android.view.ViewGroup;
import android.view.WindowManager;
import android.widget.BaseAdapter;
import android.widget.GridView;
import android.widget.Scroller;

/**
 * 自定义ViewGroup(横向滚动)
 */
public class ScrollViewGroup extends ViewGroup {
  //滚动计算辅助类
  private Scroller mScroller;
  //屏幕宽度
  private int screenWidth;
  //可以移动的最大距离
  private int mMaxDistance;
  //自定义手势监听类
  private ScrollTouchLisener mTouchLisener;
  //手势监听
  private GestureDetector mDetector;

  private BaseAdapter mAdapter;

  /**
   * 使用new关键字创建对象的时候调用
   */
  public ScrollViewGroup(Context context) {
    this(context, null);
  }

  /**
   * 在XML文件中使用的时候调用
   */
  public ScrollViewGroup(Context context, AttributeSet attrs) {
    this(context, attrs, 0);
  }

  /**
   * 在xml文件中调用,并且使用了自定义属性的时候调用
   */
  public ScrollViewGroup(Context context, AttributeSet attrs, int defStyleAttr) {
    super(context, attrs, defStyleAttr);
    init(context);
  }

  /**
   * 初始化方法
   * 初始化滚动辅助类Scroller以及计算出屏幕宽度
   */
  private void init(Context context) {
    //初始化辅助类
    mScroller = new Scroller(context);
    //获取屏幕宽度
    WindowManager manager = (WindowManager) context
        .getSystemService(Context.WINDOW_SERVICE);
    DisplayMetrics outMetrics = new DisplayMetrics();
    manager.getDefaultDisplay().getMetrics(outMetrics);
    screenWidth = outMetrics.widthPixels;
    //手势指示器初始化
    mTouchLisener = new ScrollTouchLisener();
    mDetector = new GestureDetector(context, mTouchLisener);
  }

  /**
   * 滚动时需要重写的方法,用于控制滚动
   */
  @Override
  public void computeScroll() {
    //判断滚动时候停止
    if (mScroller.computeScrollOffset()) {
      //滚动到指定的位置
      scrollTo(mScroller.getCurrX(), mScroller.getCurrY());
      //这句话必须写,否则不能实时刷新
      invalidate();
    }
  }

  /**
   * 手指触屏事件监听
   */
  @Override
  public boolean onTouchEvent(MotionEvent event) {
    mDetector.onTouchEvent(event);
    if (event.getAction() == MotionEvent.ACTION_UP) {
      this.onUp(event);
    }
    return true;
  }


  public void setAdapter(BaseAdapter adapter) {
    this.mAdapter = adapter;
    requestLayout();
  }

  /*
   *测量方法,测量父布局的宽度和高度
   */
  @Override
  protected void onMeasure(int widthMeasureSpec, int heightMeasureSpec) {
    removeAllViews();
    for (int i = 0; i 0)
        throw new IllegalStateException("view can host only one direct child");
      ((ViewGroup) child).getChildAt(0).layout(0,0,child.getWidth(),child.getHeight());
    }

  }
  @Override
  public LayoutParams generateLayoutParams(AttributeSet attrs) {
    return new MarginLayoutParams(getContext(), attrs);
  }

  /*
   *按下事件 ACTION_DOWN
   */
  public boolean onDown(MotionEvent e) {
    //得到最后一个子View
    View lastChild = getChildAt(getChildCount() - 1);
    //获取滑动的最大滑动距离(最后一个Child的右边框的坐标减去屏幕的宽度)
    int finalyChild = (int) (lastChild.getX() + lastChild.getWidth() - screenWidth);
    mMaxDistance = finalyChild;
    //如果停止滚动则取消动画(即手指按下就停止滚动)
    if (!mScroller.isFinished()) {
      mScroller.abortAnimation();
    }
    return false;
  }

  /*
  *抬起事件 ACTION_UP
  */
  public boolean onUp(MotionEvent e) {
    //如果滑动的距离小于第一个控件的最左边(0)则回弹至(0,0)点
    if (getScrollX() <= 0) {
      scrollTo(0, 0);
    }
    //如果滑动的距离大于最大可滑动距离则滑动到最后一个子View
    if (getScrollX() >= mMaxDistance) {
      scrollTo(mMaxDistance, 0);
    }
    //刷新界面
    invalidate();
    return false;
  }

  /*
   *ACTION_DOWN 、短按不移动
   */
  public void onShowPress(MotionEvent e) {
  }

  /*
   *短按ACTION_DOWN、ACTION_UP
   */
  public boolean onSingleTapUp(MotionEvent e) {
    return false;
  }

  /*
   *ACTION_DOWN 、慢滑动
   */
  public boolean onScroll(MotionEvent e1, MotionEvent e2, float distanceX, float distanceY) {
    //滚动
    scrollBy((int) distanceX, 0);
    return false;
  }

  // ACTION_DOWN 、长按不滑动
  public void onLongPress(MotionEvent e) {
  }

  /*
   *ACTION_DOWN 、快滑动、 ACTION_UP
   */
  public boolean onFling(MotionEvent e1, MotionEvent e2, float velocityX, float velocityY) {
    mScroller.fling(getScrollX(), 0, (int) -velocityX, 0, 0, mMaxDistance, 0, 0);
    return false;
  }

  /**
   * 自定义手势监听类
   */
  private class ScrollTouchLisener implements GestureDetector.OnGestureListener {

    //按下事件
    @Override
    public boolean onDown(MotionEvent e) {
      return ScrollViewGroup.this.onDown(e);
    }

    //单击事件
    @Override
    public void onShowPress(MotionEvent e) {
      ScrollViewGroup.this.onShowPress(e);
    }

    //手指抬起事件
    @Override
    public boolean onSingleTapUp(MotionEvent e) {
      return ScrollViewGroup.this.onSingleTapUp(e);
    }

    //滚动事件
    @Override
    public boolean onScroll(MotionEvent e1, MotionEvent e2, float distanceX, float distanceY) {
      return ScrollViewGroup.this.onScroll(e1, e2, distanceX, distanceY);
    }

    //长按事件
    @Override
    public void onLongPress(MotionEvent e) {
      ScrollViewGroup.this.onLongPress(e);
    }

    //滑动事件
    @Override
    public boolean onFling(MotionEvent e1, MotionEvent e2, float velocityX, float velocityY) {
      return ScrollViewGroup.this.onFling(e1, e2, velocityX, velocityY);
    }
  }

}

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


推荐阅读
  • 在更换电脑或重装系统时,用户经常需要处理诸如备份收藏夹、电子邮件、用户配置文件和常用文档等任务。尽管这些操作并不复杂,但却相当繁琐。本文介绍了一种利用Windows 7中的“轻松传送”功能,高效便捷地在两台电脑之间同步数据的方法,大大简化了这一过程。 ... [详细]
  • 本文深入探讨了Java多线程环境下的同步机制及其应用,重点介绍了`synchronized`关键字的使用方法和原理。`synchronized`关键字主要用于确保多个线程在访问共享资源时的互斥性和原子性。通过具体示例,如在一个类中使用`synchronized`修饰方法,展示了如何实现线程安全的代码块。此外,文章还讨论了`ReentrantLock`等其他同步工具的优缺点,并提供了实际应用场景中的最佳实践。 ... [详细]
  • 在 Android 应用开发中,实现全屏模式和无标题栏设计是提升用户体验的重要手段。本文详细介绍了如何通过 Java 代码实现取消标题栏 `this.requestWindowFeature(Window.FEATURE_NO_TITLE)`,并进一步探讨了全屏模式的多种实现方法和最佳实践,帮助开发者打造更加沉浸式和美观的用户界面。 ... [详细]
  • 在Android开发中,BroadcastReceiver(广播接收器)是一个重要的组件,广泛应用于多种场景。本文将深入解析BroadcastReceiver的工作原理、应用场景及其具体实现方法,帮助开发者更好地理解和使用这一组件。通过实例分析,文章详细探讨了静态广播的注册方式、生命周期管理以及常见问题的解决策略,为开发者提供全面的技术指导。 ... [详细]
  • 提升Android开发效率:Clean Code的最佳实践与应用
    在Android开发中,提高代码质量和开发效率是至关重要的。本文介绍了如何通过Clean Code的最佳实践来优化Android应用的开发流程。以SQLite数据库操作为例,详细探讨了如何编写高效、可维护的SQL查询语句,并将其结果封装为Java对象。通过遵循这些最佳实践,开发者可以显著提升代码的可读性和可维护性,从而加快开发速度并减少错误。 ... [详细]
  • 在探讨Hibernate框架的高级特性时,缓存机制和懒加载策略是提升数据操作效率的关键要素。缓存策略能够显著减少数据库访问次数,从而提高应用性能,特别是在处理频繁访问的数据时。Hibernate提供了多层次的缓存支持,包括一级缓存和二级缓存,以满足不同场景下的需求。懒加载策略则通过按需加载关联对象,进一步优化了资源利用和响应时间。本文将深入分析这些机制的实现原理及其最佳实践。 ... [详细]
  • Android中将独立SO库封装进JAR包并实现SO库的加载与调用
    在Android开发中,将独立的SO库封装进JAR包并实现其加载与调用是一个常见的需求。本文详细介绍了如何将SO库嵌入到JAR包中,并确保在外部应用调用该JAR包时能够正确加载和使用这些SO库。通过这种方式,开发者可以更方便地管理和分发包含原生代码的库文件,提高开发效率和代码复用性。文章还探讨了常见的问题及其解决方案,帮助开发者避免在实际应用中遇到的坑。 ... [详细]
  • ButterKnife 是一款用于 Android 开发的注解库,主要用于简化视图和事件绑定。本文详细介绍了 ButterKnife 的基础用法,包括如何通过注解实现字段和方法的绑定,以及在实际项目中的应用示例。此外,文章还提到了截至 2016 年 4 月 29 日,ButterKnife 的最新版本为 8.0.1,为开发者提供了最新的功能和性能优化。 ... [详细]
  • REST与RPC:选择哪种API架构风格?
    在探讨REST与RPC这两种API架构风格的选择时,本文首先介绍了RPC(远程过程调用)的概念。RPC允许客户端通过网络调用远程服务器上的函数或方法,从而实现分布式系统的功能调用。相比之下,REST(Representational State Transfer)则基于资源的交互模型,通过HTTP协议进行数据传输和操作。本文将详细分析两种架构风格的特点、适用场景及其优缺点,帮助开发者根据具体需求做出合适的选择。 ... [详细]
  • 在 CentOS 6.5 系统上部署 VNC 服务器的详细步骤与配置指南
    在 CentOS 6.5 系统上部署 VNC 服务器时,首先需要确认 VNC 服务是否已安装。通常情况下,VNC 服务默认未安装。可以通过运行特定的查询命令来检查其安装状态。如果查询结果为空,则表明 VNC 服务尚未安装,需进行手动安装。此外,建议在安装前确保系统的软件包管理器已更新至最新版本,以避免兼容性问题。 ... [详细]
  • SSAS入门指南:基础知识与核心概念解析
    ### SSAS入门指南:基础知识与核心概念解析Analysis Services 是一种专为决策支持和商业智能(BI)解决方案设计的数据引擎。该引擎能够为报告和客户端应用提供高效的分析数据,并支持在多维数据模型中构建高性能的分析应用。通过其强大的数据处理能力和灵活的数据建模功能,Analysis Services 成为了现代 BI 系统的重要组成部分。 ... [详细]
  • 本文探讨了如何有效地构建和优化微信公众平台账号,涵盖了用户信息管理、内容创作与发布、互动策略及数据分析等方面。通过合理设置用户信息字段,如用户名、昵称、密码、真实姓名和性别等,确保账号的安全性和用户体验。同时,文章还介绍了如何利用微信公众平台的各项功能,提升用户参与度和品牌影响力。 ... [详细]
  • 单链表的高效遍历及性能优化策略
    本文探讨了单链表的高效遍历方法及其性能优化策略。在单链表的数据结构中,插入操作的时间复杂度为O(n),而遍历操作的时间复杂度为O(n^2)。通过在 `LinkList.h` 和 `main.cpp` 文件中对单链表进行封装,我们实现了创建和销毁功能的优化,提高了单链表的使用效率。此外,文章还介绍了几种常见的优化技术,如缓存节点指针和批量处理,以进一步提升遍历性能。 ... [详细]
  • 小王详解:内部网络中最易理解的NAT原理剖析,挑战你的认知极限
    小王详解:内部网络中最易理解的NAT原理剖析,挑战你的认知极限 ... [详细]
  • 初探性能优化:入门指南与实践技巧
    在编程领域,常有“尚未精通编码便急于优化”的声音。为了从性能优化的角度提升代码质量,本文将带领读者初步探索性能优化的基本概念与实践技巧。即使程序看似运行良好,数据处理效率仍有待提高,通过系统学习性能优化,能够帮助开发者编写更加高效、稳定的代码。文章不仅介绍了性能优化的基础知识,还提供了实用的调优方法和工具,帮助读者在实际项目中应用这些技术。 ... [详细]
author-avatar
管怡6440_368
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有