大家在進(jìn)行安卓開發(fā)的時(shí)候,經(jīng)常用到日期比如在課程安排,工作安排,日志等地方,今天給大家?guī)淼氖亲屓掌谧笥覠o限的滑動,并支持自定義顯示效果的方法。一起來學(xué)習(xí)下。
	
以上是本次所要達(dá)到的效果
使用說明:
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 兩個(gè)方法
@Override  public void refreshContent() {    //你的代碼 你可以在這里定義你的顯示規(guī)則    super.refreshContent();  }   @Override  public IDayRenderer copy() {    return new CustomDayView(context , layoutResource);  }新建CustomDayView實(shí)例,并作為參數(shù)構(gòu)建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 你需要實(shí)現(xiàn)這兩個(gè)方法來啟動日歷并裝填進(jìn)數(shù)據(jù)
@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();  }使用此方法回調(diào)日歷點(diǎn)擊事件
private void initListener() {    onSelectDateListener = new OnSelectDateListener() {      @Override      public void onSelectDate(CalendarDate date) {        //your code      }       @Override      public void onSelectOtherMonth(int offset) {        //偏移量 -1表示上一個(gè)月 , 1表示下一個(gè)月        monthPager.selectOtherMonth(offset);      }    };  }使用此方法初始化日歷標(biāo)記數(shù)據(jù)
private void initMarkData() {    HashMap markData = new HashMap<>();    //1表示紅點(diǎn),0表示灰點(diǎn)    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添加上相關(guān)監(jiān)聽
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;    }  }DownloadGradle: 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'  }以上就是本次效果所用到的所有代碼和說明,大家有任何問題可以在下方的留言地方討論。
新聞熱點(diǎn)
疑難解答
圖片精選