当前位置: 首页 > news >正文

Android 第三方库CalendarView

Android 第三方库CalendarView

根据需求和库的使用方式,自己弄了一个合适自己的日历,仅记录下,方便下次弄其他样式的日历。地址

需求:

  1. 只显示当月的数据

  2. 默认的月视图有矩形的线

  3. 选中的天数也要有选中的矩形框

  4. 今天的item需要显示“今”

  5. 部分有记录的要显示图片

1.布局代码

<com.haibin.calendarview.CalendarViewandroid:id="@+id/calendarView"android:layout_width="match_parent"android:layout_height="wrap_content"android:background="#fff"app:calendar_height="46dp"app:calendar_padding="10dp"app:current_month_lunar_text_color="#CFCFCF"app:current_month_text_color="#333333"app:min_year="2004"app:month_view="com.haibin.calendarviewproject.zhengq.SimpleMonthView"app:month_view_show_mode="mode_only_current"app:other_month_text_color="#e1e1e1"app:scheme_text="假"app:scheme_text_color="#333"app:scheme_theme_color="#333"app:selected_text_color="#333"app:selected_theme_color="#333"app:week_background="#fff"app:week_text_color="#111"app:week_view="com.haibin.calendarviewproject.zhengq.SimpleWeekView"app:year_view_day_text_color="#333333"app:year_view_day_text_size="9sp"app:year_view_month_text_color="#ff0000"app:year_view_month_text_size="20sp"app:year_view_scheme_color="#f17706" />

month_view_show_mode属性可以设置 只显示当月数据

calendar_height属性可以设置 月item的高度

2.默认的矩形框

@Override
protected void onDrawText(Canvas canvas, Calendar calendar, int x, int y, boolean hasScheme, boolean isSelected) {//这里绘制文本,不要再问我怎么隐藏农历了,不要再问我怎么把某个日期换成特殊字符串了,要怎么显示你就在这里怎么画,你不画就不显示,是看你想怎么显示日历的,而不是看框架canvas.drawRect(x, y, x + mItemWidth, y + mItemHeight, mRectPaint);...
}

3.选中的矩形框

@Overrideprotected boolean onDrawSelected(Canvas canvas, Calendar calendar, int x, int y, boolean hasScheme) {//这里绘制选中的日子样式,看需求需不需要继续调用onDrawScheme//绘制选中的日期矩形mSelectedPaint.setColor(getContext().getResources().getColor(R.color.solar_background));mSelectedPaint.setStyle(Paint.Style.STROKE);canvas.drawRect(x, y, x + mItemWidth, y + mItemHeight, mSelectedPaint);
​return true;//如果这里是false选中一个带Scheme的item,不显示Scheme,设置true就会显示}

4.scheme

/*** 绘制标记的事件日子** @param canvas   canvas* @param calendar 日历calendar* @param x        日历Card x起点坐标* @param y        日历Card y起点坐标*/
@Override
protected void onDrawScheme(Canvas canvas, Calendar calendar, int x, int y) {//这里绘制标记的日期样式,想怎么操作就怎么操作
​//绘制到日期数字的左边canvas.drawText(calendar.getScheme(), x + mPadding, y + mItemHeight / 2 + mPadding, mTextPaint);
​//绘制一张图片Drawable drawable = getContext().getResources().getDrawable(R.mipmap.record_gong_l);//第一层第一个canvas.drawBitmap(BitmapUtils.drawable2Bitmap(drawable), x + mPadding, y + mPadding, mTextPaint);//第一层第二个canvas.drawBitmap(BitmapUtils.drawable2Bitmap(drawable), x + mItemWidth / 2 - drawable.getIntrinsicWidth() / 2, y + mPadding, mTextPaint);//第一层第三个canvas.drawBitmap(BitmapUtils.drawable2Bitmap(drawable), x + mItemWidth - drawable.getIntrinsicWidth() - mPadding, y + mPadding, mTextPaint);
​//第二层第三个canvas.drawBitmap(BitmapUtils.drawable2Bitmap(drawable), x + mItemWidth - drawable.getIntrinsicWidth() - mPadding,y + mItemHeight / 2 - drawable.getIntrinsicHeight() / 2, mTextPaint);
​//第三层第一个canvas.drawBitmap(BitmapUtils.drawable2Bitmap(drawable), x + mPadding,y - mPadding + mItemHeight - drawable.getIntrinsicHeight(), mTextPaint);//第三层第二个canvas.drawBitmap(BitmapUtils.drawable2Bitmap(drawable), x + mItemWidth / 2 - drawable.getIntrinsicWidth() / 2,y - mPadding + mItemHeight - drawable.getIntrinsicHeight(), mTextPaint);//第三层第三个canvas.drawBitmap(BitmapUtils.drawable2Bitmap(drawable), x + mItemWidth - drawable.getIntrinsicWidth() - mPadding,y - mPadding + mItemHeight - drawable.getIntrinsicHeight(), mTextPaint);
}

5.完成

6.注意

1.Paint颜色设置

    public SimpleMonthView(Context context) {super(context);mRectPaint.setStyle(Paint.Style.STROKE);mRectPaint.setStrokeWidth(dipToPx(context, 0.5f));mRectPaint.setColor(0x88efefef);//这里的演示不能设置透明度为1的颜色,会覆盖选中的颜色
​mPadding = dipToPx(getContext(), 4);mTextPaint.setTextSize(dipToPx(context, 8));mTextPaint.setTextSize(dipToPx(context, 10));mTextPaint.setColor(getContext().getResources().getColor(R.color.solar_background));//黑色mTextPaint.setAntiAlias(true);mTextPaint.setFakeBoldText(true);}

2.SimpleWeekView和SimpleMonthView要一样的

3.onDrawSelected中的return true;,否则不会显示scheme

4.不足之处:日历旁边会显示白色的边框

http://www.lryc.cn/news/106512.html

相关文章:

  • 钉钉群消息推送
  • css clip-path 属性介绍
  • Python之pyinstaller打包exe填坑总结
  • Form Generator 表单JSON数据储存以及JSON回显表单
  • Python - OpenCV识别条形码、二维码(已封装,拿来即用)
  • Python如何快速实现爬取网页?
  • 怎么才能远程控制笔记本电脑?
  • 【3】C++实现多进程、多线程
  • Linux用户权限信息、chmod以及chown命令
  • 利用vscode--sftp,将本地项目/文件上传到远程服务器中详细教程
  • java List和数组相互转换的方法总结
  • 【音频分离】demucs V3的环境搭建及训练(window)
  • JAVA环境变量配置(windows)
  • 爬虫教程1_Xpath 入门教程
  • Python爬虫教程篇+图形化整理数据(数学建模可用)
  • 数字安全观察·数据安全分析方向
  • Kubernetes系列-配置存储 ConfigMap Secret
  • bacnet ddc控制器如何通过485口转发Modbus协议控制modbus执行设备
  • 构建易于运维的 AI 训练平台:存储选型与最佳实践
  • 前期自学Java的基础部分总结(二)
  • Altova MissionKit 2023Crack
  • Linux CentOS上快速安装Docker并运行服务
  • TCP三次握手与四次断开
  • 关于前端与APP录音相关的笔记
  • 【Java】SpringBoot项目整合FreeMarker加快页面访问速度
  • conda环境下安装opencv-python包
  • JVM面试题--类加载器
  • js怎么计算当前一周的日期
  • 【图论】差分约束
  • 13 springboot项目——准备数据和dao类