用gridview模仿日历并实现签到功能

  最近 公司没事,闲得慌……(项目开发完了,是不是 都这样……^_^ 23333)

第二次写博客  大神勿喷 只针对 刚出生的猿猴们  谢谢。。。

前段时间公司要求在app上添加一个签到功能,也就是 什么签到领奖什么的,其实 那来什么奖啊 就是 送一些代金券 想促进消费……


首先,提到签到 估计 大部分人想到的都是日历, 我开始也在想 调用系统的日历做签到,然而 好像在系统日历上做更改有点复杂,反正我是不会的。所以 马上就想到了gridview 这个控件,只需要每排固定7个 好像就和日历一样了,而且可以随意定制。  好,就这样愉快的决定了 。action……


1、xml布局、 我把 星期几  单独列出来 排在顶部 是为了 让gridview 适配器 显得 简单一些。

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:orientation="vertical" 
    android:background="@color/white"
    >
    
    <Button
        android:id="@+id/btn_sign_in"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:background="@drawable/btn_sign_in_pressd"
        android:layout_gravity="center_horizontal"
         android:layout_marginTop="30dp"
         android:text="签到"
         android:textColor="@color/white"
         android:textSize="18sp"
        />
    
    <LinearLayout 
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:background="@color/white"
        android:gravity="center"
        android:orientation="vertical"
        android:layout_marginLeft="15dp"
        android:layout_marginRight="15dp"
         android:layout_marginTop="20dp"
         android:padding="10dp"
        >
    
    <TextView
        android:id="@+id/text_date"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:textColor="@color/title_color"
        android:textSize="12sp"
        android:text="2015年11月30日"
        />
    <LinearLayout 
        android:layout_marginTop="5dp"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:orientation="horizontal"
        android:weightSum="7"
        >
        <TextView 
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:layout_weight="1"
            android:text="周日"
            android:textColor="@color/title_color"
            android:textSize="10sp"
            android:gravity="center"
            />
        <TextView 
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:layout_weight="1"
            android:text="周一"
            android:textColor="@color/title_color"
            android:textSize="10sp"
            android:gravity="center"
            />
        <TextView 
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:layout_weight="1"
            android:text="周二"
            android:textColor="@color/title_color"
            android:textSize="10sp"
            android:gravity="center"
            />
        <TextView 
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:layout_weight="1"
            android:text="周三"
            android:textColor="@color/title_color"
            android:textSize="10sp"
            android:gravity="center"
            />
        <TextView 
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:layout_weight="1"
            android:text="周四"
            android:textColor="@color/title_color"
            android:textSize="10sp"
            android:gravity="center"
            />
        <TextView 
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:layout_weight="1"
            android:text="周五"
            android:textColor="@color/title_color"
            android:textSize="10sp"
            android:gravity="center"
            />
        <TextView 
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:layout_weight="1"
            android:text="周六"
            android:textColor="@color/title_color"
            android:textSize="10sp"
            android:gravity="center"
            />
        
    </LinearLayout>
    
     <com.example.signDate.MyGridViewR
                    android:id="@+id/grid_date"
                    android:layout_width="match_parent"
                    android:layout_height="wrap_content"
                    android:background="@color/white"
                    android:horizontalSpacing="1dp"
                    android:numColumns="7"
                    android:scrollbars="none"
                    android:verticalSpacing="5dp" 
                    android:layout_marginTop="10dp"
                    >
                </com.example.signDate.MyGridViewR>
    
     <Button 
         android:id="@+id/next_day"
         android:layout_width="wrap_content"
         android:layout_height="wrap_content"
         android:text="穿越到未来(+1天)"
         android:layout_marginTop="10dp"
         />
     
    </LinearLayout>
    
    
</LinearLayout>

2、然后 activity 代码  主要是 生成一些模拟数据 和 对签到过后 对页面的 一些操作 ,其中 对点击签到 和获得数据的方法中,可以加入自己的 逻辑代码和http请求。

package com.example.signDate;

import java.text.SimpleDateFormat;
import java.util.ArrayList;
import java.util.Calendar;

import android.os.Bundle;
import android.util.TypedValue;
import android.view.View;
import android.view.View.OnClickListener;
import android.widget.Button;
import android.widget.TextView;
import android.widget.Toast;

import com.example.gridviewsigndate.R;
/**
 * 
 * @author zhangyao
 *
 */
public class SignInActivity extends BaseActivity implements OnClickListener{
	
	private TextView textDate;
	
	private MyGridViewR gridDate;  
	
	private DateSignInAdapter dateAdapter;
	
	private Button btnSignin;  
	
	private String dateStr ; // 用于显示几年几月 判断  当月1号 为星期几
	
	private ArrayList<String> listDate = new ArrayList<String>();

	private Calendar now = Calendar.getInstance(); //当前时间
	
	private int count = 0;
	
	private Button nextDay;// 穿越。。。。。:)
	
	
	private int mMonth = 0;
	
	@Override
	protected void onCreate(Bundle arg0) {
		// TODO Auto-generated method stub
		super.onCreate(arg0);
		setContentView(R.layout.activity_sign_in);
		
		initView();
		
		for (int i = 0; i < 31; i++) { //暂时默认一个月31天  0代表未签到 1 代表签到  应该从服务器获取 实际的信息,这里模拟 
 			
			listDate.add("0");
			
		}
		
		getSignInfo();
	}

	private void initView() {
		// TODO Auto-generated method stub
		textDate = (TextView) findViewById(R.id.text_date);
		gridDate = (MyGridViewR) findViewById(R.id.grid_date);
		btnSignin =  (Button) findViewById(R.id.btn_sign_in);
		
		nextDay  =  (Button) findViewById(R.id.next_day);
		
		btnSignin.setOnClickListener(this);
		
		nextDay.setOnClickListener(this);
	}
	
	/**
	 * 获取签到信息
	 */
	private void getSignInfo() {
		//根据实际情况可以从后台 获取 当月的天数 星期几 和 签到的连续天数等信息 
		
		dateStr = new String();
		
		dateStr = now.get(Calendar.YEAR)+"-"+(now.get(Calendar.MONTH)+1)+"-01";	
		
		textDate.setText(now.get(Calendar.YEAR)+"-"+(now.get(Calendar.MONTH)+1)+"-"+now.get(Calendar.DAY_OF_MONTH));
		
		setDate(dateStr);
	}

	protected void setDate(String dateStr) {
		// TODO Auto-generated method stub
		
		int start = 0; //用 每月的一号是周几  来判断 从哪个 位移量 开始计算
		
		SimpleDateFormat format = new SimpleDateFormat("yyyy-MM-dd");
		
		Calendar date = Calendar.getInstance();
		try {
			date.setTime(format.parse(dateStr));
			
			switch (date.get(Calendar.DAY_OF_WEEK)) {
			case 1: //周日
				
				start = 0;
				
				break;
			case 2: //周一
				
				start = 1;
				
				break;
			case 3:
				
				start = 2;
				
				break;
			case 4:
				
				start = 3;
				
				break;
			case 5:
				
				start = 4;
				
				break;
			case 6:
				
				start = 5;
				
				break;
			case 7:
				
				start = 6;
				
				break;
			default:
				break;
			}
			
			
		} catch (Exception e) {
			// TODO: handle exception
		}
		
		ArrayList<String> lists = new ArrayList<String>();
		lists.clear();
		count = 0;
		for (int i = 0; i < listDate.size(); i++) {
			
			lists.add(listDate.get(i));
			if ("1".equals(listDate.get(i))) { //计算 已经签到的天数
				
				count++;
				
			}
		}
		
		dateAdapter = new DateSignInAdapter(SignInActivity.this, lists,start);
		gridDate.setAdapter(dateAdapter);
		dateAdapter.notifyDataSetChanged();
		
		//当天已签到
		if ("1".equals(lists.get(Integer.valueOf(now.get(Calendar.DAY_OF_MONTH)) - 1))) {
			
			btnSignin.setTextSize(TypedValue.COMPLEX_UNIT_SP , 12);
			btnSignin.setText("已签到"+count+"次");
			
		}
		else {
			btnSignin.setTextSize(TypedValue.COMPLEX_UNIT_SP , 18);
			btnSignin.setText("签到");
		}
		
	}

	

	@Override
	public void onClick(View v) {
		
		if (v == btnSignin) {
			
			if ("0".equals(listDate.get(Integer.valueOf(now.get(Calendar.DAY_OF_MONTH)) - 1))) {
				
				Signin(now.get(Calendar.DAY_OF_MONTH));
				
			}
			else {
				Toast.makeText(getApplicationContext(), "今天已经签到过了", Toast.LENGTH_SHORT).show();;
			}
			
		}
		if (v == nextDay) {
			
			now.add(Calendar.DATE, 1); // +1天
			
			//处理穿越到 下一个月  把签到数据清零。。。
			int month = now.get(Calendar.MONTH)+1;
			
			if (mMonth == 0) {
				
				mMonth = month;
			}
			else {
				if (mMonth != month) {
					
					listDate.clear();
					for (int i = 0; i < 31; i++) { //暂时默认一个月31天  0代表未签到 1 代表签到  应该从服务器获取 实际的信息,这里模拟 
			 			
						listDate.add("0");
						
					}
					mMonth = month;
				}
				
			}
			
			getSignInfo();
			
		}
		
	}

	/**
	 * 签到
	 * @param day 
	 */
	private void Signin(int day) {
		//发送http 请求 到服务器 根据返回值 判断是否签到 成功, 这里本地模拟。。
		
		listDate.set(day-1, "1");
		getSignInfo();
		
	}
}

3、 剩下的就是对 适配器的操作了,看起来是非常的简单的,和对列表的adapter一样的 

package com.example.signDate;

import java.util.ArrayList;

import com.example.gridviewsigndate.R;

import android.content.Context;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.BaseAdapter;
import android.widget.Button;
/**
 * 
 * @author zhangyao
 *
 */
public class DateSignInAdapter extends BaseAdapter{

	private Context context = null;
	private ArrayList<String> list = null;
	private int start = 0; //用于 判断 星期几
	
	public DateSignInAdapter(Context context,ArrayList<String> list, int start2) {
		// TODO Auto-generated constructor stub
		this.context = context;
		this.list = list;
		this.start = start2;
	}
	
	@Override
	public int getCount() {
		// TODO Auto-generated method stub
		return list.size() + start;
	}

	@Override
	public Object getItem(int position) {
		// TODO Auto-generated method stub
		return null;
	}

	@Override
	public long getItemId(int position) {
		// TODO Auto-generated method stub
		return 0;
	}

	@Override
	public View getView(int position, View convertView, ViewGroup parent) {
		// TODO Auto-generated method stub
		ViewHolder viewHolder;
		
		
		if (convertView == null)
		{
			viewHolder = new ViewHolder();
			convertView = LayoutInflater.from(context).inflate(R.layout.gridview_date, null);
			
			viewHolder.btnDate = (Button) convertView.findViewById(R.id.btn_date);
			
			convertView.setTag(viewHolder);
			
		} else{
			
			viewHolder = (ViewHolder) convertView.getTag();
		}
		if (position < start) {
			
			viewHolder.btnDate.setVisibility(View.INVISIBLE);
		}
		else {
			viewHolder.btnDate.setVisibility(View.VISIBLE);
		}
		
		if (list != null && position >= start) {
			
			//根据状态显示对于的 颜色
			if ("0".equals(list.get(position - start))) {
				
				viewHolder.btnDate.setBackgroundResource(R.drawable.sign_gray);
				viewHolder.btnDate.setTextColor(context.getResources().getColor(R.color.deep_gray));
			}
			else if("1".equals(list.get(position - start))) {
				
				viewHolder.btnDate.setBackgroundResource(R.drawable.sign_current);
				viewHolder.btnDate.setTextColor(context.getResources().getColor(R.color.white));
			}
			else {
				viewHolder.btnDate.setTextColor(context.getResources().getColor(R.color.deep_gray));
				viewHolder.btnDate.setBackgroundResource(R.drawable.sign_gray);
			}
			
			viewHolder.btnDate.setText(position - start + 1+""); //显示 号数。。因为 positopn从0开始 所以 +1;
			
		}
		return convertView;
	}
	
	final class ViewHolder
	{
		Button btnDate;
		
	}

}

最后:需要注意的就是  也许你这个页面比较长需要用到scrollview等滑动的控件,这样 gridview 就会出现只显示一行的问题,不过没关系,网上那些大神几年前就遇到过这种问题了,所以搬一个现成的定制gridview就好了  嘿嘿  拿来主义  - -!

package com.example.signDate;
import android.content.Context;
import android.util.AttributeSet;
import android.widget.GridView;
/**
 * 用于 解决 gridview 嵌套进  scrollview 等需要 滑动的页面时  只显示一行的问题
 * @author zhangyao
 * @version 1.0.0
 */
public class MyGridViewR extends GridView {

	public MyGridViewR(Context context, AttributeSet attrs) {
		super(context, attrs);
	}

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

	public MyGridViewR(Context context, AttributeSet attrs, int defStyle) {
		super(context, attrs, defStyle);
	}

	@Override
	public void onMeasure(int widthMeasureSpec, int heightMeasureSpec) {

		int expandSpec = MeasureSpec.makeMeasureSpec(Integer.MAX_VALUE >> 2,
				MeasureSpec.AT_MOST);
		super.onMeasure(widthMeasureSpec, expandSpec);
	}
}
在最后附上源码,第二次 就这样结束了(这么快,我还没回过神来。。。) 大神勿喷!

http://download.csdn.net/detail/yygool/9392804(1积分下载, 手里积分紧张,赚点积分 就免费。)

  • 2
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值