AndroidカスタムカレンダーCalenderコード実現


制品は机能に署名して、机能に署名して1つのカレンダーに基づいて行います。だから、要求によってカレンダーをカスタマイズしました。

カスタムコントロールはandroidを作ることを信じています。
(1)まずクラスを作成し、容器類またはコントロールを継承します。 
(2)次に設定したい属性などがあります。atrsフォルダにあります。 
(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://xiazai.jb51.net/201609/yuanma/AndroidCalenderDemo(jb 51.net)rar
カレンダーをカスタマイズしてからサインします。カスタマイズしたCalendarの中で少し修正すればいいです。効果図を見てください。 

これは大丈夫です。DEMO:http://xiazai.jb51.net/201609/yuanma/AndroidCalender(jb 51.net)rar
いくつかの方法を追加したデモ:http://xiazai.jb51.net/201609/yuanma/Calenderchange(jb 51.net)rar
以上が本文の全部です。皆さんの勉強に役に立つように、私たちを応援してください。