Android登录界面之用户数据保存+服务器上传(一)

                                                     基本功:完整版登录界面

所谓完整版登录界面是带验证的登录界面

也是是包含注册登录

注册:包含输入用户手机或者信息,发起请求,等待服务器发来验证码或者怎样的注册,同时注册信息保存在本地数据库,等待下一次打开app,自动登录

登录:将用户请求输入的内容与后台保存的数据做对比验证,例如:密码一致则获得通过

===================================================================================

最基本的:

首先完成登录界面,希望大家做正规的登录界面,这些重用性非常高,一次做好,多个项目收益,所以这次我们不做最简单的demo,而是往一个基本的产品去靠方向。

首先:

两个界面

登录界面+注册界面:

学会定义:一些参数,背景之类的的设置最好不要设置在布局文件中,为了重复利用以及规范化一律定义在

styles  dimen   drawable color  等里面:

例如:

 

 

   <ImageView
            android:id="@+id/back"
            android:padding="12dp"
            android:layout_width="@dimen/title_bar_height"
            android:layout_height="@dimen/title_bar_height"
            android:src="@drawable/jiantou" />

 这里面:布局高度,宽度都是定义在dimen里面。现在放上登录注册的效果图来看一下:



 

简单的登录+注册界面,这里需要注意的,不仅是布局参数设置,还有对密码的监控,这里我们需要判断密码输入是不是符合规范,在安卓里面一般布局函数还是在xml里面设置的,但是有的时候需要动态监控控件状态在xml里面肯定是不好配置的,所以我们需要代码监控,做好完整版的登录注册,这一步也是需要做的,现在看一下我们负责监控的.java函数:

首先看一下这个px dp互转的概念:

在xml布局文件中,我们既可以设置px,也可以设置dp(或者dip)。一般情况下,我们都会选择使用dp,这样可以保证不同屏幕分辨率的机器上布局一致。但是在代码中,如何处理呢?很多控件的方法中都只提供了设置px的方法,例如setPadding,并没有提供设置dp的方法。这个时候,如果需要设置dp的话,就要将dp转换成px了。

下面是显示了px 与dp互转的概念例子:

public class dp_to_px {
	
	/**
	* 根据手机的分辨率从 dp 的单位 转成为 px(像素)
	*/
	public static int dip2px(Context context, float dpValue) {
	  final float scale = context.getResources().getDisplayMetrics().density;
	  return (int) (dpValue * scale + 0.5f);
	}

	/**
	* 根据手机的分辨率从 px(像素) 的单位 转成为 dp
	*/
	public static int px2dip(Context context, float pxValue) {
	  final float scale = context.getResources().getDisplayMetrics().density;
	  return (int) (pxValue / scale + 0.5f);
	}

}

 这是一个公式,宝宝自己也不是很懂公式转换原理,反正需要的时候网上一搜就有很多例子,拿来直接用就行了。

现在正式贴上ClearEditText的监控代码:


 

public class ClearEditText extends EditText implements OnFocusChangeListener,
		TextWatcher {
	/**
	 * 带删除按钮的editText
	 */
	private Drawable mClearDrawable; // 删除图标
	private boolean hasFoucs;
	private int imgdp = 0;

	public ClearEditText(Context context) {
		this(context, null);
	}

	public ClearEditText(Context context, AttributeSet attrs) {
		this(context, attrs, android.R.attr.editTextStyle);
	}

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

	private void init() {
		// 获取EditText的DrawableRight,假如没有设置就使用默认的图片,2是获得右边的图片 顺序是左上右下(0,1,2,3)
		/*
		 * 主要是为了处理监听输入密码后的一键删除的图标
		 */
		mClearDrawable = getCompoundDrawables()[2];
		if (mClearDrawable == null) {
			mClearDrawable = getResources().getDrawable(R.drawable.dian);
		}

		imgdp = dip2px(getContext(), 30); // 转换dp
		// rightDrawable.setBounds(0, 0, imgdp, imgdp);
		mClearDrawable.setBounds(0, 0, imgdp, imgdp);
		// 默认设置隐藏图标
		setClearIconVisible(false);
		// 设置焦点改变的监听
		setOnFocusChangeListener(this);
		// 设置输入框里面内容发生改变的监听
		addTextChangedListener(this);
	}

	@Override
	//这里判断输入时,自动设置edit清空。目的为删除“输入密码”这一句的提示语
	public boolean onTouchEvent(MotionEvent event) {
		if (event.getAction() == MotionEvent.ACTION_UP) {
			if (getCompoundDrawables()[2] != null) {
				boolean touchable = event.getX() > (getWidth() - getTotalPaddingRight())
						&& (event.getX() < ((getWidth() - getPaddingRight())));
				if (touchable) {
					this.setText("");
				}
			}
		}
		return super.onTouchEvent(event);
	}

	/**
	 * 当ClearEditText焦点发生变化的时候,判断里面字符串长度设置清除图标的显示与隐藏?
	 */
	@Override
	public void onFocusChange(View v, boolean hasFocus) {
		this.hasFoucs = hasFocus;
		//有焦点,字符大于0显示删除图标
		if (hasFocus) {
			setClearIconVisible(getText().length() > 0);
		} else {
			setClearIconVisible(false);
		}
	}

	/**
	 * 设置清除图标的显示与隐藏,调用setCompoundDrawables为EditText绘制上去
	 * 
	 * @param visible
	 */
	protected void setClearIconVisible(boolean visible) {
		Drawable right = visible ? mClearDrawable : null;
		setCompoundDrawables(getCompoundDrawables()[0],
				getCompoundDrawables()[1], right, getCompoundDrawables()[3]);
	}

	/**
	 * 当输入框里面内容发生变化的时候回调的方法
	 */
	@Override
	public void onTextChanged(CharSequence s, int start, int count, int after) {
		if (hasFoucs) {
			setClearIconVisible(s.length() > 0);
		}
	}

	@Override
	public void beforeTextChanged(CharSequence s, int start, int count,
			int after) {

	}

	@Override
	public void afterTextChanged(Editable s) {

	}

	// dp转px
	public static int dip2px(Context context, float dpValue) {
		final float scale = context.getResources().getDisplayMetrics().density;
		return (int) (dpValue * scale + 0.5f);

	}
}

 登录的布局:



 下面几节课,会涉及到数据库,及动态读取用户信息,用户信息保存到本地,以及向后台的服务请求

 

 

 

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值