Android自定义View实现课程表表格

自己闲下来时间写的一个课表控件,使用的自定义LinearLayout,里面View都是用代码实现的,最终效果如下图,写的可能有问题希望多多指点

创建一个自定义LinearLayout 控件用来装载课程的信息和课程的周数,和节数大概的布局三这样的

根据上面的看来觉得总体布局我分了两个 上面的星期是一个 下面的节数和格子是一个  总体使用Vertical  而单独内部者使用了Horizontal布局  中间使用了两种布局线条 是这样的

/**
 * 横的分界线
 *
 * @return
 */
 private View getWeekTransverseLine() {
 TextView mWeekline = new TextView(getContext());
 mWeekline.setBackgroundColor(getResources().getColor(R.color.view_line));
 mWeekline.setHeight(TimeTableLineHeight);
 mWeekline.setWidth(LayoutParams.FILL_PARENT);
 return mWeekline;
 }

 /**
 * 竖向分界线
 *
 * @return
 */
 private View getWeekVerticalLine() {
 TextView mWeekline = new TextView(getContext());
 mWeekline.setBackgroundColor(getResources().getColor(R.color.view_line));
 mWeekline.setHeight(dip2px(TimeTableWeekNameHeight));
 mWeekline.setWidth((TimeTableLineHeight));
 return mWeekline;
 }

下面就看其它的View

那就从上到下开始先看星期的布局

 private void initView() {

 mHorizontalWeekLayout = new LinearLayout(getContext());
 mHorizontalWeekLayout.setOrientation(HORIZONTAL);

 mVerticalWeekLaout = new LinearLayout(getContext());
 mVerticalWeekLaout.setOrientation(HORIZONTAL);
 //表格
 for (int i = 0; i <= WEEKNUM; i++) {
  switch (i) {
  case 0:
   //课表出的0,0格子 空白的
   TextView mTime = new TextView(getContext());
   mTime.setHeight(dip2px(TimeTableWeekNameHeight));
   mTime.setWidth((dip2px(TimeTableNumWidth)));
   mHorizontalWeekLayout.addView(mTime);

   //绘制1~MAXNUM
   LinearLayout mMonday = new LinearLayout(getContext());
   ViewGroup.LayoutParams mm = new ViewGroup.LayoutParams(dip2px(TimeTableNumWidth), dip2px(MAXNUM * TimeTableHeight) + MAXNUM * 2);
   mMonday.setLayoutParams(mm);
   mMonday.setOrientation(VERTICAL);
   for (int j = 1; j <= MAXNUM; j++) {
   TextView mNum = new TextView(getContext());
   mNum.setGravity(Gravity.CENTER);
   mNum.setTextColor(getResources().getColor(R.color.text_color));
   mNum.setHeight(dip2px(TimeTableHeight));
   mNum.setWidth(dip2px(TimeTableNumWidth));
   mNum.setTextSize(14);
   mNum.setText(j + "");
   mMonday.addView(mNum);
   mMonday.addView(getWeekTransverseLine());
   }
   mVerticalWeekLaout.addView(mMonday);
   break;
  case 1:
  case 2:
  case 3:
  case 4:
  case 5:
  case 6:
  case 7:
   // 设置显示星期一 到星期天
   LinearLayout mHoriView = new LinearLayout(getContext());
   mHoriView.setOrientation(VERTICAL);
   TextView mWeekName = new TextView(getContext());
   mWeekName.setTextColor(getResources().getColor(R.color.text_color));
   mWeekName.setWidth(((getViewWidth() - dip2px(TimeTableNumWidth))) / WEEKNUM);
   mWeekName.setHeight(dip2px(TimeTableWeekNameHeight));
   mWeekName.setGravity(Gravity.CENTER);
   mWeekName.setTextSize(16);
   mWeekName.setText(weekname[i - 1]);
   mHoriView.addView(mWeekName);
   mHorizontalWeekLayout.addView(mHoriView);

   List<TimeTableModel> mListMon = new ArrayList<>();
   //遍历出星期1~7的课表
   for (TimeTableModel timeTableModel : mListTimeTable) {
   if (timeTableModel.getWeek() == i) {
    mListMon.add(timeTableModel);
   }
   }
   //添加
   LinearLayout mLayout = getTimeTableView(mListMon, i);
   mLayout.setOrientation(VERTICAL);
   ViewGroup.LayoutParams linearParams = new ViewGroup.LayoutParams((getViewWidth() - dip2px(20)) / WEEKNUM, LayoutParams.FILL_PARENT);
   mLayout.setLayoutParams(linearParams);
   mLayout.setWeightSum(1);
   mVerticalWeekLaout.addView(mLayout);
   break;

  default:
   break;
  }
  TextView l = new TextView(getContext());
  l.setHeight(dip2px(TimeTableHeight * MAXNUM) + MAXNUM * 2);
  l.setWidth(2);
  l.setBackgroundColor(getResources().getColor(R.color.view_line));
  mVerticalWeekLaout.addView(l);
  mHorizontalWeekLayout.addView(getWeekVerticalLine());
 }
 addView(mHorizontalWeekLayout);
 addView(getWeekTransverseLine());
 addView(mVerticalWeekLaout);
 addView(getWeekTransverseLine());
 }

TimeTableModel

package com.shallcheek.timetale;

public class TimeTableModel {
 private int id;
 private int startnum;
 private int endnum;
 private int week;
 private String starttime="";
 private String endtime="";
 private String name="";
 private String teacher="";
 private String classroom="";
 private String weeknum="";

 @Override
 public String toString() {
 return "TimeTableModel [id=" + id + ", startnum=" + startnum
 + ", endnum=" + endnum + ", week=" + week + ", starttime="
 + starttime + ", endtime=" + endtime + ", name=" + name
 + ", teacher=" + teacher + ", classroom=" + classroom
 + ", weeknum=" + weeknum + "]";
 }

 public int getId() {
 return id;
 }

 public int getStartnum() {
 return startnum;
 }

 public int getEndnum() {
 return endnum;
 }

 public int getWeek() {
 return week;
 }

 public String getStarttime() {
 return starttime;
 }

 public String getEndtime() {
 return endtime;
 }

 public String getName() {
 return name;
 }

 public String getTeacher() {
 return teacher;
 }

 public String getClassroom() {
 return classroom;
 }

 public String getWeeknum() {
 return weeknum;
 }

 public void setId(int id) {
 this.id = id;
 }

 public void setStartnum(int startnum) {
 this.startnum = startnum;
 }

 public void setEndnum(int endnum) {
 this.endnum = endnum;
 }

 public void setWeek(int week) {
 this.week = week;
 }

 public void setStarttime(String starttime) {
 this.starttime = starttime;
 }

 public void setEndtime(String endtime) {
 this.endtime = endtime;
 }

 public void setName(String name) {
 this.name = name;
 }

 public void setTeacher(String teacher) {
 this.teacher = teacher;
 }

 public void setClassroom(String classroom) {
 this.classroom = classroom;
 }

 public void setWeeknum(String weeknum) {
 this.weeknum = weeknum;
 }
 public TimeTableModel() {
 // TODO Auto-generated constructor stub
 }

 public TimeTableModel(int id, int startnum, int endnum, int week,
 String starttime, String endtime, String name, String teacher,
 String classroom, String weeknum) {
 super();
 this.id = id;
 this.startnum = startnum;
 this.endnum = endnum;
 this.week = week;
 this.starttime = starttime;
 this.endtime = endtime;
 this.name = name;
 this.teacher = teacher;
 this.classroom = classroom;
 this.weeknum = weeknum;
 }

}

TimeTableView

package com.shallcheek.timetale;

import java.util.ArrayList;
import java.util.List;

import android.content.Context;
import android.graphics.Canvas;
import android.util.AttributeSet;
import android.util.Log;
import android.view.Gravity;
import android.view.View;
import android.view.ViewGroup;
import android.view.WindowManager;
import android.widget.LinearLayout;
import android.widget.TextView;
import android.widget.Toast;

/**
 * 课表显示View
 *
 * @author shallcheek
 */
public class TimeTableView extends LinearLayout {
 /**
 * 配色数组
 */
 public static int colors[] = {R.drawable.select_label_san,
  R.drawable.select_label_er, R.drawable.select_label_si,
  R.drawable.select_label_wu, R.drawable.select_label_liu,
  R.drawable.select_label_qi, R.drawable.select_label_ba,
  R.drawable.select_label_jiu, R.drawable.select_label_sss,
  R.drawable.select_label_se, R.drawable.select_label_yiw,
  R.drawable.select_label_sy, R.drawable.select_label_yiwu,
  R.drawable.select_label_yi, R.drawable.select_label_wuw};
 private final static int START = 0;
 //最大节数
 public final static int MAXNUM = 12;
 //显示到星期几
 public final static int WEEKNUM = 7;
 //单个View高度
 private final static int TimeTableHeight = 50;
 //线的高度
 private final static int TimeTableLineHeight = 2;
 private final static int TimeTableNumWidth = 20;
 private final static int TimeTableWeekNameHeight = 30;
 private LinearLayout mHorizontalWeekLayout;//第一行的星期显示
 private LinearLayout mVerticalWeekLaout;//课程格子
 private String[] weekname = {"一", "二", "三", "四", "五", "六", "七"};
 public static String[] colorStr = new String[20];
 int colornum = 0;
 //数据源
 private List<TimeTableModel> mListTimeTable = new ArrayList<TimeTableModel>();

 public TimeTableView(Context context) {
 super(context);
 }

 public TimeTableView(Context context, AttributeSet attributeSet) {
 super(context, attributeSet);
 }

 @Override
 protected void onDraw(Canvas canvas) {
 super.onDraw(canvas);
 }

 /**
 * 横的分界线
 *
 * @return
 */
 private View getWeekTransverseLine() {
 TextView mWeekline = new TextView(getContext());
 mWeekline.setBackgroundColor(getResources().getColor(R.color.view_line));
 mWeekline.setHeight(TimeTableLineHeight);
 mWeekline.setWidth(LayoutParams.FILL_PARENT);
 return mWeekline;
 }

 /**
 * 竖向分界线
 *
 * @return
 */
 private View getWeekVerticalLine() {
 TextView mWeekline = new TextView(getContext());
 mWeekline.setBackgroundColor(getResources().getColor(R.color.view_line));
 mWeekline.setHeight(dip2px(TimeTableWeekNameHeight));
 mWeekline.setWidth((TimeTableLineHeight));
 return mWeekline;
 }

 private void initView() {

 mHorizontalWeekLayout = new LinearLayout(getContext());
 mHorizontalWeekLayout.setOrientation(HORIZONTAL);

 mVerticalWeekLaout = new LinearLayout(getContext());
 mVerticalWeekLaout.setOrientation(HORIZONTAL);
 //表格
 for (int i = 0; i <= WEEKNUM; i++) {
  switch (i) {
  case 0:
   //课表出的0,0格子 空白的
   TextView mTime = new TextView(getContext());
   mTime.setHeight(dip2px(TimeTableWeekNameHeight));
   mTime.setWidth((dip2px(TimeTableNumWidth)));
   mHorizontalWeekLayout.addView(mTime);

   //绘制1~MAXNUM
   LinearLayout mMonday = new LinearLayout(getContext());
   ViewGroup.LayoutParams mm = new ViewGroup.LayoutParams(dip2px(TimeTableNumWidth), dip2px(MAXNUM * TimeTableHeight) + MAXNUM * 2);
   mMonday.setLayoutParams(mm);
   mMonday.setOrientation(VERTICAL);
   for (int j = 1; j <= MAXNUM; j++) {
   TextView mNum = new TextView(getContext());
   mNum.setGravity(Gravity.CENTER);
   mNum.setTextColor(getResources().getColor(R.color.text_color));
   mNum.setHeight(dip2px(TimeTableHeight));
   mNum.setWidth(dip2px(TimeTableNumWidth));
   mNum.setTextSize(14);
   mNum.setText(j + "");
   mMonday.addView(mNum);
   mMonday.addView(getWeekTransverseLine());
   }
   mVerticalWeekLaout.addView(mMonday);
   break;
  case 1:
  case 2:
  case 3:
  case 4:
  case 5:
  case 6:
  case 7:
   // 设置显示星期一 到星期天
   LinearLayout mHoriView = new LinearLayout(getContext());
   mHoriView.setOrientation(VERTICAL);
   TextView mWeekName = new TextView(getContext());
   mWeekName.setTextColor(getResources().getColor(R.color.text_color));
   mWeekName.setWidth(((getViewWidth() - dip2px(TimeTableNumWidth))) / WEEKNUM);
   mWeekName.setHeight(dip2px(TimeTableWeekNameHeight));
   mWeekName.setGravity(Gravity.CENTER);
   mWeekName.setTextSize(16);
   mWeekName.setText(weekname[i - 1]);
   mHoriView.addView(mWeekName);
   mHorizontalWeekLayout.addView(mHoriView);

   List<TimeTableModel> mListMon = new ArrayList<>();
   //遍历出星期1~7的课表
   for (TimeTableModel timeTableModel : mListTimeTable) {
   if (timeTableModel.getWeek() == i) {
    mListMon.add(timeTableModel);
   }
   }
   //添加
   LinearLayout mLayout = getTimeTableView(mListMon, i);
   mLayout.setOrientation(VERTICAL);
   ViewGroup.LayoutParams linearParams = new ViewGroup.LayoutParams((getViewWidth() - dip2px(20)) / WEEKNUM, LayoutParams.FILL_PARENT);
   mLayout.setLayoutParams(linearParams);
   mLayout.setWeightSum(1);
   mVerticalWeekLaout.addView(mLayout);
   break;

  default:
   break;
  }
  TextView l = new TextView(getContext());
  l.setHeight(dip2px(TimeTableHeight * MAXNUM) + MAXNUM * 2);
  l.setWidth(2);
  l.setBackgroundColor(getResources().getColor(R.color.view_line));
  mVerticalWeekLaout.addView(l);
  mHorizontalWeekLayout.addView(getWeekVerticalLine());
 }
 addView(mHorizontalWeekLayout);
 addView(getWeekTransverseLine());
 addView(mVerticalWeekLaout);
 addView(getWeekTransverseLine());
 }

 private int getViewWidth() {
 WindowManager wm = (WindowManager) getContext().getSystemService(
  Context.WINDOW_SERVICE);
 return wm.getDefaultDisplay().getWidth();
 }

 private View addStartView(int startnum, final int week, final int start) {
 LinearLayout mStartView = new LinearLayout(getContext());
 mStartView.setOrientation(VERTICAL);
 for (int i = 1; i < startnum; i++) {
  TextView mTime = new TextView(getContext());
  mTime.setGravity(Gravity.CENTER);
  mTime.setHeight(dip2px(TimeTableHeight));
  mTime.setWidth(dip2px(TimeTableHeight));
  mStartView.addView(mTime);
  mStartView.addView(getWeekTransverseLine());
  final int num = i;
  //这里可以处理空白处点击添加课表
  mTime.setOnClickListener(new OnClickListener() {
  @Override
  public void onClick(View v) {
   Toast.makeText(getContext(), "星期" + week + "第" + (start + num) + "节", Toast.LENGTH_LONG).show();
  }
  });

 }
 return mStartView;
 }

 /**
 * 星期一到星期天的课表
 *
 * @param model
 * @param week
 * @return
 */
 private LinearLayout getTimeTableView(List<TimeTableModel> model, int week) {
 LinearLayout mTimeTableView = new LinearLayout(getContext());
 mTimeTableView.setOrientation(VERTICAL);
 int modesize = model.size();
 if (modesize <= 0) {
  mTimeTableView.addView(addStartView(MAXNUM + 1, week, 0));
 } else {
  for (int i = 0; i < modesize; i++) {
  if (i == 0) {
   //添加的0到开始节数的空格
   mTimeTableView.addView(addStartView(model.get(0).getStartnum(), week, 0));
   mTimeTableView.addView(getMode(model.get(0)));
  } else if (model.get(i).getStartnum() - model.get(i - 1).getStartnum() > 0) {
   //填充
   mTimeTableView.addView(addStartView(model.get(i).getStartnum() - model.get(i - 1).getEndnum(), week, model.get(i - 1).getEndnum()));
   mTimeTableView.addView(getMode(model.get(i)));
  }
  if (i + 1 == modesize) {
   mTimeTableView.addView(addStartView(MAXNUM - model.get(i).getEndnum(), week, model.get(i).getEndnum()));
  }
  }
 }
 return mTimeTableView;
 }

 /**
 * 获取单个课表View 也可以自定义我这个
 *
 * @param model 数据类型
 * @return
 */
 @SuppressWarnings("deprecation")
 private View getMode(final TimeTableModel model) {
 LinearLayout mTimeTableView = new LinearLayout(getContext());
 mTimeTableView.setOrientation(VERTICAL);
 TextView mTimeTableNameView = new TextView(getContext());
 int num = model.getEndnum() - model.getStartnum();
 mTimeTableNameView.setHeight(dip2px((num + 1) * TimeTableHeight) + num * 2);
 mTimeTableNameView.setTextColor(getContext().getResources().getColor(
  android.R.color.white));
 mTimeTableNameView.setWidth(dip2px(50));
 mTimeTableNameView.setTextSize(16);
 mTimeTableNameView.setGravity(Gravity.CENTER);
 mTimeTableNameView.setText(model.getName() + "@" + model.getClassroom());
 mTimeTableView.addView(mTimeTableNameView);
 mTimeTableView.addView(getWeekTransverseLine());
 mTimeTableView.setBackgroundDrawable(getContext().getResources()
  .getDrawable(colors[getColorNum(model.getName())]));
 mTimeTableView.setOnClickListener(new OnClickListener() {
  @Override
  public void onClick(View v) {
  Toast.makeText(getContext(), model.getName() + "@" + model.getClassroom(), Toast.LENGTH_LONG).show();
  }
 });
 return mTimeTableView;
 }

 /**
 * 转换dp
 *
 * @param dpValue
 * @return
 */
 public int dip2px(float dpValue) {
 float scale = getContext().getResources().getDisplayMetrics().density;
 return (int) (dpValue * scale + 0.5f);
 }

 public void setTimeTable(List<TimeTableModel> mlist) {
 this.mListTimeTable = mlist;
 for (TimeTableModel timeTableModel : mlist) {
  addTimeName(timeTableModel.getName());
 }
 initView();
 invalidate();
 }

 /**
 * 输入课表名循环判断是否数组存在该课表 如果存在输出true并退出循环 如果不存在则存入colorSt[20]数组
 *
 * @param name
 */
 private void addTimeName(String name) {
 boolean isRepeat = true;
 for (int i = 0; i < 20; i++) {
  if (name.equals(colorStr[i])) {
  isRepeat = true;
  break;
  } else {
  isRepeat = false;
  }
 }
 if (!isRepeat) {
  colorStr[colornum] = name;
  colornum++;
 }
 }

 /**
 * 获取数组中的课程名
 *
 * @param name
 * @return
 */
 public static int getColorNum(String name) {
 int num = 0;
 for (int i = 0; i < 20; i++) {
  if (name.equals(colorStr[i])) {
  num = i;
  }
 }
 return num;
 }
}

布局文件

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
 android:layout_width="fill_parent"
 android:layout_height="fill_parent"
 android:background="@android:color/white"
 android:orientation="vertical" >

 <ScrollView
 android:layout_width="fill_parent"
 android:layout_height="fill_parent" >

 <com.shallcheek.timetale.TimeTableView
  android:id="@+id/main_timetable_ly"
  android:layout_width="fill_parent"
  android:layout_height="fill_parent"
  android:orientation="vertical" >
 </com.shallcheek.timetale.TimeTableView>
 </ScrollView>

</LinearLayout>

最新版查看:查看地址

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

(0)

相关推荐

  • Android自定义View实现微信支付密码输入框

    本文实例为大家分享了Android实现微信支付密码输入框的具体代码,供大家参考,具体内容如下 效果图 项目中使用到了支付密码功能,其实这类界面是比较常用的,涉及支付密码的输入的一般都会用到对的,所以单独地把这部分抽取出来,有需要的朋友可以拿去用哈! 效果就是支付,弹出密码框,输入密码,这个过程密码不可见,并且提供一个输入完毕的监听! 这个弹出层呢,其实就是一个DialogFragment,逻辑封装在其内部 一.弹出层进出动画 (anim文件) push_bottom_in.xml <?xml v

  • Android自定义View的使用及其原理知识点总结

    在Android开发中,系统提供给我们的UI控件是有限的,当我们需要使用一些特殊的控件的时候,只靠系统提供的控件,可能无法达到我们想要的效果,这时,就需要我们自定义一些控件,来完成我们想要的效果了.下面,我就来讲讲自定义控件的那些事. 首先,我来讲讲Android的控件架构.Android的控件可以被分为两类,分别是ViewGroup和View.在ViewGroup中可以包含多个View,并且管理他们.控件树就是有这两个部分组成的,控件树的上层负责的是下层控件的绘制和测量以及交互.我们在Acti

  • Android自定义view渐变圆形动画

    本文实例为大家分享了Android自定义view渐变圆形动画的具体代码,供大家参考,具体内容如下 直接上效果图 自定义属性 attrs.xml文件 <resources> <declare-styleable name="ProgressRing"> <!--进度起始色--> <attr name="pr_progress_start_color" format="color" /> <!--

  • Android自定义view仿iOS弹出框效果

    本文实例为大家分享了Android自定义view仿iOS弹出框的具体代码,供大家参考,具体内容如下 运行效果图 自定义对话框的使用,仿照ios.从底部弹出,类似pop窗口.包括消息.图片.列表及对话框. 好了,用法都会,直接贴上代码 1.layout布局文件 view_actionsheet.xml <?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:android="ht

  • Android自定义view实现车载可调整轨迹线

    本文实例为大家分享了Android自定义view完成车载可调整轨迹线的具体代码,供大家参考,具体内容如下 同事做的view,拿过来做个记录. /** * */ package com.text.myviewdemo.view; import org.apache.http.conn.routing.RouteInfo.LayerType; import android.content.Context; import android.graphics.Canvas; import android.

  • Android自定义view仿IOS开关效果

    本文主要讲解如何在 Android 下实现高仿 iOS 的开关按钮,并非是在 Android 自带的 ToggleButton 上修改,而是使用 API 提供的 onDraw.onMeasure.Canvas 方法,纯手工绘制.基本原理就是在 Canvas 上叠着放两张图片,上面的图片根据手指触摸情况,不断移动,实现开关效果. 废话不说,上效果图,看看怎么样 样式如下: 网上也有实现这种效果的,但是大都滑动没中间消失的动画,或者是很复杂,今天用简单的绘图方式实现,重点就在onDraw里绘图. 功

  • Android自定义View实现公交成轨迹图

    本文实例为大家分享了Android自定义View实现公交成轨迹图的具体代码,供大家参考,具体内容如下 总体分析下:水平方向recyclewview,item包含定位点,站台位置和站台名称. 下面看实现: 1.继承framelayout,实现构造方法: public class BusStopPlateView extends FrameLayout { ... public BusStopPlateView(@NonNull Context context) { super(context);

  • Android自定义View实现课程表表格

    自己闲下来时间写的一个课表控件,使用的自定义LinearLayout,里面View都是用代码实现的,最终效果如下图,写的可能有问题希望多多指点 创建一个自定义LinearLayout 控件用来装载课程的信息和课程的周数,和节数大概的布局三这样的 根据上面的看来觉得总体布局我分了两个 上面的星期是一个 下面的节数和格子是一个  总体使用Vertical  而单独内部者使用了Horizontal布局  中间使用了两种布局线条 是这样的 /** * 横的分界线 * * @return */ priva

  • Android自定义View实现仿GitHub的提交活跃表格

    说明 本文可能需要一些基础知识点,如Canvas,Paint,Path,Rect等类的基本使用,建议不熟悉的同学可以学习GcsSloop安卓自定义View教程目录,会帮助很大. 上图就是github的提交表格,直观来看可以分为几个部分进行绘制: (1)各个月份的小方格子,并且色彩根据提交次数变化,由浅到深 (2)右下边的颜色标志,我们右对齐就可以了 (3)左边的星期,原图是从周日画到周六,我们从周一画到周日 (4)上面的月份,我们只画出1-12月 (5)点击时候弹出当天的提交情况,由一个小三角和

  • Android自定义view绘制表格的方法

    本文实例为大家分享了Android自定义view绘制表格的具体代码,供大家参考,具体内容如下 先上效果图 平时很少有这样的表格需求,不过第一想法就是自定义view绘制表格,事实上我确实是用的canvas来绘制的,整个过程看似复杂,实为简单,计算好各个点的坐标后事情就完成一半了.不废话show code import android.content.Context; import android.graphics.Canvas; import android.graphics.Color; imp

  • Android 自定义LayoutManager实现花式表格

    如果你对RecyclerView原理还不是特别了解,非常建议你读一下. 本文的项目也是学习自定义LayoutManager绝佳资料,大家有需要的可以好好拜读. 前言 表格是自打我进公司以后就使用的控件,起初使用的是ScrollablePanel,从一开始的被花式吊打,到后期的熟练使用. 大佬写的控件确实给我的工作带来了极大的方便,不过还是有些问题存在: 无法实现不规则的表格 其核心是二层RecyclerView的嵌套,如果只用一层RecyclerView将会带来性能的提升 多个RecyclerV

  • Android自定义View原理(实战)

    目录 1.为什么需要自定义View 2.自定义View的基本方法 3.自定义View的属性如何操作 4.View的视图结构 5.View的坐标系 6.View树的绘制流程 6.1 measure过程 6.2 分析自定义ViewGroup的onMeasure过程 6.3 分析自定义ViewGroup的onLayout过程 6.4 自定义Layout实战 6.5 细节 1.为什么需要自定义View Android系统内置的View不满足我们的业务需求 2.自定义View的基本方法 onMeasure

  • Android自定义view实现阻尼效果的加载动画

    效果: 需要知识: 1. 二次贝塞尔曲线 2. 动画知识 3. 基础自定义view知识 先来解释下什么叫阻尼运动 阻尼振动是指,由于振动系统受到摩擦和介质阻力或其他能耗而使振幅随时间逐渐衰减的振动,又称减幅振动.衰减振动.[1] 不论是弹簧振子还是单摆由于外界的摩擦和介质阻力总是存在,在振动过程中要不断克服外界阻力做功,消耗能量,振幅就会逐渐减小,经过一段时间,振动就会完全停下来.这种振幅随时间减小的振动称为阻尼振动.因为振幅与振动的能量有关,阻尼振动也就是能量不断减少的振动.阻尼振动是非简谐运

  • Android 自定义View 密码框实例代码

    暴露您view中所有影响可见外观的属性或者行为. •通过XML添加和设置样式 •通过元素的属性来控制其外观和行为,支持和重要事件交流的事件监听器 详细步骤见:Android 自定义View步骤 效果图展示: 支持的样式 可以通过XML定义影响外边和行为的属性如下 边框圆角值,边框颜色,分割线颜色,边框宽度,密码长度,密码大小,密码颜色 <declare-styleable name="PasswordInputView"> <attr name="borde

  • Android自定义View详解

    转载请标明出处:http://blog.csdn.net/lmj623565791/article/details/24252901 很多的Android入门程序猿来说对于Android自定义View,可能都是比较恐惧的,但是这又是高手进阶的必经之路,所有准备在自定义View上面花一些功夫,多写一些文章.先总结下自定义View的步骤: 1.自定义View的属性 2.在View的构造方法中获得我们自定义的属性 [ 3.重写onMesure ] 4.重写onDraw 我把3用[]标出了,所以说3不一

  • Android自定义View中attrs.xml的实例详解

    Android自定义View中attrs.xml的实例详解 我们在自定义View的时候通常需要先完成attrs.xml文件 在values中定义一个attrs.xml 然后添加相关属性 这一篇先详细介绍一下attrs.xml的属性. <?xml version="1.0" encoding="utf-8"?> <resources> //自定义属性名,定义公共属性 <attr name="titleText" for

  • Android自定义View 仿QQ侧滑菜单的实现代码

    先看看QQ的侧滑效果 分析一下 先上原理图(不知道能否表达的清楚 ==) -首先这里使用了 Android 的HorizontalScrollView 水平滑动布局作为容器,当然我们需要继承它自定义一个侧滑视图 - 这个容器里面有一个父布局(一般用LinerLayout,本demo用的是),这个父布局里面有且只有两个子控件(布局),初始状态菜单页的位置在Y轴上存在偏移这样可以就可以形成主页叠在菜单页的上方的视觉效果:然后在滑动的过程程中 逐渐修正偏移,最后菜单页和主页并排排列.原理搞清了实现起来

随机推荐