AndroidカスタムカレンダーCalenderコード実現
制品は机能に署名して、机能に署名して1つのカレンダーに基づいて行います。だから、要求によってカレンダーをカスタマイズしました。
カスタムコントロールはandroidを作ることを信じています。
(1)まずクラスを作成し、容器類またはコントロールを継承します。
(2)次に設定したい属性などがあります。atrsフォルダにあります。
(3)次にクラス内で属性の設定やレイアウトなどの機能を追加します。
実際には、ユーザー定義のカレンダーの問題は多くないです。多くの人はgridViewを通して充填すればいいと考えています。確かにこのように、主に毎月の初日の位置を表示しています。毎月何日間表示していますか?
現在の曜日を判断してカレンダーの塗りつぶしを行いますが、塗りつぶしの大きさはその月の日数より大きくしてはいけません。その月の最初の日は何曜日ですか?
コード:
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
以上が本文の全部です。皆さんの勉強に役に立つように、私たちを応援してください。
カスタムコントロールは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
以上が本文の全部です。皆さんの勉強に役に立つように、私たちを応援してください。