android实现切换日期左右无限滑动效果

所属分类: 软件编程 / Android 阅读数: 58
收藏 0 赞 0 分享

大家在进行安卓开发的时候,经常用到日期比如在课程安排,工作安排,日志等地方,今天给大家带来的是让日期左右无限的滑动,并支持自定义显示效果的方法。一起来学习下。

以上是本次所要达到的效果

使用说明:

XML布局

新建XML布局

RecyclerView的layout_behavior为com.ldf.calendar.behavior.RecyclerViewBehavior

<android.support.design.widget.CoordinatorLayout
    android:id="@+id/content"
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    android:layout_weight="1">
 
    <com.ldf.calendar.view.MonthPager
      android:id="@+id/calendar_view"
      android:layout_width="match_parent"
      android:layout_height="300dp"
      android:background="#fff">
    </com.ldf.calendar.view.MonthPager>
 
    <android.support.v7.widget.RecyclerView
      android:id="@+id/list"
      android:layout_width="match_parent"
      android:layout_height="wrap_content"
      app:layout_behavior="com.ldf.calendar.behavior.RecyclerViewBehavior"
      android:background="#c2c2c2"
      android:layout_gravity="bottom"/>
 
  </android.support.design.widget.CoordinatorLayout>

自定义日历样式
新建CustomDayView继承自DayView并重写refreshContent 和 copy 两个方法

@Override
  public void refreshContent() {
    //你的代码 你可以在这里定义你的显示规则
    super.refreshContent();
  }
 
  @Override
  public IDayRenderer copy() {
    return new CustomDayView(context , layoutResource);
  }

新建CustomDayView实例,并作为参数构建CalendarViewAdapter

CustomDayView customDayView = new CustomDayView(
      context , R.layout.custom_day);
  calendarAdapter = new CalendarViewAdapter(
        context ,
        onSelectDateListener ,
        Calendar.MONTH_TYPE ,
        customDayView);

初始化View
目前来看 相比于Dialog选择日历 我的控件更适合于Activity/Fragment在Activity的onCreate 或者Fragment的onCreateView 你需要实现这两个方法来启动日历并装填进数据

@Override
  protected void onCreate(@Nullable Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_syllabus);
    initCalendarView();
  }
  
  private void initCalendarView() {
    initListener();
    CustomDayView customDayView = new CustomDayView(
      context , R.layout.custom_day);
    calendarAdapter = new CalendarViewAdapter(
        context ,
        onSelectDateListener ,
        Calendar.MONTH_TYPE ,
        customDayView);
    initMarkData();
    initMonthPager();
  }

使用此方法回调日历点击事件

private void initListener() {
    onSelectDateListener = new OnSelectDateListener() {
      @Override
      public void onSelectDate(CalendarDate date) {
        //your code
      }
 
      @Override
      public void onSelectOtherMonth(int offset) {
        //偏移量 -1表示上一个月 , 1表示下一个月
        monthPager.selectOtherMonth(offset);
      }
    };
  }

使用此方法初始化日历标记数据

private void initMarkData() {
    HashMap markData = new HashMap<>();
    //1表示红点,0表示灰点
    markData.put("2017-8-9" , "1");
    markData.put("2017-7-9" , "0");
    markData.put("2017-6-9" , "1");
    markData.put("2017-6-10" , "0");
    calendarAdapter.setMarkData(markData);
  }

使用此方法给MonthPager添加上相关监听

monthPager.addOnPageChangeListener(new MonthPager.OnPageChangeListener() {
      @Override
      public void onPageScrolled(int position, float positionOffset, int positionOffsetPixels) {
      }
 
      @Override
      public void onPageSelected(int position) {
        mCurrentPage = position;
        currentCalendars = calendarAdapter.getAllItems();
        if(currentCalendars.get(position % currentCalendars.size()) instanceof Calendar){
          //you code
        }
      }
 
      @Override
      public void onPageScrollStateChanged(int state) {
      }
    });

重写onWindowFocusChanged方法,使用此方法得知calendar和day的尺寸

 @Override
  public void onWindowFocusChanged(boolean hasFocus) {
    super.onWindowFocusChanged(hasFocus);
    if(hasFocus && !initiated) {
      CalendarDate today = new CalendarDate();
      calendarAdapter.notifyDataChanged(today);
      initiated = true;
    }
  }
Download

Gradle: Step 1. Add it in your root build.gradle at the end of repositories:

allprojects {
  repositories {
  ...
  maven { url 'https://www.jitpack.io' }
  }
}
Step 2. Add the dependency

  dependencies {
      compile 'com.github.MagicMashRoom:SuperCalendar:v1.3.1'
  }

以上就是本次效果所用到的所有代码和说明,大家有任何问题可以在下方的留言地方讨论。

更多精彩内容其他人还在看

Android网络编程之获取网络上的Json数据实例

这篇文章主要介绍了Android网络编程之获取网络上的Json数据实例,本文用完整的代码实例讲解了在Android中读取网络中Json数据的方法,需要的朋友可以参考下
收藏 0 赞 0 分享

Android中的windowSoftInputMode属性详解

这篇文章主要介绍了Android中的windowSoftInputMode属性详解,本文对windowSoftInputMode的9个属性做了详细总结,需要的朋友可以参考下
收藏 0 赞 0 分享

Android网络编程之UDP通信模型实例

这篇文章主要介绍了Android网络编程之UDP通信模型实例,本文给出了服务端代码和客户端代码,需要的朋友可以参考下
收藏 0 赞 0 分享

Android中使用ListView实现漂亮的表格效果

这篇文章主要介绍了Android中使用ListView实现漂亮的表格效果,本文用详细的代码实例创建了一个股票行情表格,需要的朋友可以参考下
收藏 0 赞 0 分享

Android中刷新界面的二种方法

这篇文章主要介绍了Android中刷新界面的二种方法,本文使用Handler、postInvalidate两种方法实现界面刷新,需要的朋友可以参考下
收藏 0 赞 0 分享

Android SDK三种更新失败及其解决方法

这篇文章主要介绍了Android SDK三种更新失败及其解决方法,需要的朋友可以参考下
收藏 0 赞 0 分享

Android学习笔记——Menu介绍(一)

Android3.0(API level 11)开始,Android设备不再需要专门的菜单键。随着这种变化,Android app应该取消对传统6项菜单的依赖。取而代之的是提供anction bar来提供基本的用户功能
收藏 0 赞 0 分享

Android学习笔记——Menu介绍(二)

这次将继续上一篇文章没有讲完的Menu的学习,上下文菜单(Context menu)和弹出菜单(Popup menu)
收藏 0 赞 0 分享

Android学习笔记——Menu介绍(三)

今天继续昨天没有讲完的Menu的学习,主要是Popup Menu的学习,需要的朋友可以参考下
收藏 0 赞 0 分享

Android显示网络图片实例

这篇文章主要介绍了Android显示网络图片的方法,以实例形式展示了Android程序显示网络图片的方法,非常具有实用价值,需要的朋友可以参考下
收藏 0 赞 0 分享
查看更多