自定义的一个日历Calender

简介:

产品要做签到功能,签到功能要基于一个日历来进行,所以就根据 要求自定义了一个日历


自定义控件相信做android都知道:

        (1)首先创建一个类,继承一个容器类或者是一个控件

(2)然后就是你需要设置的属性等的,在attrs文件夹中

(3)然后就是在类里边进行属性的设置以及布局等等功能的添加


   其实自定义一个日历问题都不多,很多人都会想到通过一个gridView然后填充就可以,确实是这样,主要是在显示每个月的第一天的位置以及每个月显示多少天有点绕。

        思路:通过判断当前星期几然后进行日历的填充,但是填充的大小不能大于当月天数,通过当月第一天是星期几来判断从哪个位置填充。

       代码:

package com.example.calenderdemo;

import android.content.Context;
import android.graphics.Color;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.BaseAdapter;
import android.widget.TextView;

public class CalendarViewAdapter extends BaseAdapter {

	private Context mContext;
	private int mCountDay = 49;
	private int mCurrent_mouth_Countday;
	private int mCurrent_Week;
	private int id[] = { R.string.week7, R.string.week1, R.string.week2,
			R.string.week3, R.string.week4, R.string.week5, R.string.week6 };

	public CalendarViewAdapter(Context context, int countday) {
		this.mContext = context;
		this.mCurrent_Week = Utils.getCurrentMonthStart();
		this.mCurrent_mouth_Countday = countday;
	}

	@Override
	public int getCount() {
		return mCountDay;
	}

	@Override
	public Object getItem(int position) {
		return null;
	}

	@Override
	public long getItemId(int position) {
		return position;
	}

	@Override
	public View getView(int position, View convertView, ViewGroup parent) {
		ViewHolder holder = null;
		if (convertView == null) {
			holder = new ViewHolder();
			convertView = LayoutInflater.from(mContext).inflate(
					R.layout.item_calendar, null);
			holder.mTv_calendar_day = (TextView) convertView
					.findViewById(R.id.tv_calendar_day);
			convertView.setTag(holder);
		} else
			holder = (ViewHolder) convertView.getTag();
		if (position <= 6) {
			holder.mTv_calendar_day.setTextColor(Color.BLACK);
			holder.mTv_calendar_day.setTextSize(mContext.getResources()
					.getDimension(R.dimen.text_size_7));
			holder.mTv_calendar_day.setText(mContext.getResources().getString(
					id[position]));
		} else {
			if (mCurrent_Week == 7 && (position -6) <= mCurrent_mouth_Countday) {
				holder.mTv_calendar_day.setText(position-6 + "");
			} else if (position -7>= mCurrent_Week
					&& position - mCurrent_Week -6 <= mCurrent_mouth_Countday) {
				holder.mTv_calendar_day.setText(position - mCurrent_Week -6
						+ "");
			}
		
		}
		if (position % 7 == 6) {
			holder.mTv_calendar_day.setBackgroundResource(R.drawable.line_right);
		}else if (position % 7 == 0) {
			holder.mTv_calendar_day.setBackgroundResource(R.drawable.line_left);
		}
		return convertView;
	}

	class ViewHolder {
		TextView mTv_calendar_day;
	}
}

               把gridView填充了以后一个简单的日历控件就ok了。

Demo:http://download.csdn.net/detail/u012808234/9031525


                  自定义了一个日历以后就要做签到了,签到只要在自定义的Calendar中稍稍修改下就好了,看下效果图:


看这还行,然后DEMO: http://download.csdn.net/detail/u012808234/9040009

添加了几个方法的Demo:http://download.csdn.net/detail/u012808234/9202567

相关文章
SwiftUI—方便用户选择日期的DatePicker日期拾取器
SwiftUI—方便用户选择日期的DatePicker日期拾取器
1583 0
SwiftUI—方便用户选择日期的DatePicker日期拾取器
|
10月前
lunar="false",日历插件不显示农历
lunar="false",日历插件不显示农历
66 1
|
前端开发 JavaScript 容器
开源炫酷日历、网页日历模板、自适应大小日历、win10日历
开源炫酷日历、网页日历模板、自适应大小日历、win10日历
331 0
开源炫酷日历、网页日历模板、自适应大小日历、win10日历
关于调起系统日历预填信息问题
最近开发遇到一个问题,需要调起系统日历,添加日历事件,但是会出现有些手机无法预填信息的情况;在这里对这个问题做个小记录;
117 0
关于调起系统日历预填信息问题
|
Windows
私人定制日历代码改进
2021年即将到来,小编学习了calendR这个包,并写了两篇推送。分别为: R可视乎|2021年日历大派送 calendR包—私人定制专属日历 并开源了自己的代码在github上,但是细心的读者发现代码还存在可以优化的地方。
154 0
私人定制日历代码改进
|
存储
calendR包—私人定制专属日历
前两天给大家派送了小编自己定制的2021年日历和月历,看到好多读者下载了,小编表示很欣慰😁。上期推送可见:R可视乎|2021年日历大派送 今天来说说这个包吧,非常简单,比起ggplot2包绘制日历要简单的多。
171 0
calendR包—私人定制专属日历
|
JavaScript 前端开发 小程序
小程序日历日期单选选择实现
###小程序日历日期单选选择实现拿走不谢 看图说话 ![1575796331_1_](https://yqfile.alicdn.com/51bf41a1c0d8c45753874db1776d692395757936.
1601 0
小程序日历日期单选选择实现