欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页

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

程序员文章站 2022-06-01 20:49:10
...

                                                     基本功:完整版登录界面

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

也是是包含注册登录

注册:包含输入用户手机或者信息,发起请求,等待服务器发来验证码或者怎样的注册,同时注册信息保存在本地数据库,等待下一次打开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里面。现在放上登录注册的效果图来看一下:


Android登录界面之用户数据保存+服务器上传(一)
            
    
    博客分类: Android项目实战 登录注册界面设计dp px转换AndroidMVC模式 
 
Android登录界面之用户数据保存+服务器上传(一)
            
    
    博客分类: Android项目实战 登录注册界面设计dp px转换AndroidMVC模式 

简单的登录+注册界面,这里需要注意的,不仅是布局参数设置,还有对密码的监控,这里我们需要判断密码输入是不是符合规范,在安卓里面一般布局函数还是在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);

	}
}

 登录的布局:


Android登录界面之用户数据保存+服务器上传(一)
            
    
    博客分类: Android项目实战 登录注册界面设计dp px转换AndroidMVC模式 
 下面几节课,会涉及到数据库,及动态读取用户信息,用户信息保存到本地,以及向后台的服务请求

 

 

 

  • Android登录界面之用户数据保存+服务器上传(一)
            
    
    博客分类: Android项目实战 登录注册界面设计dp px转换AndroidMVC模式 
  • 大小: 6.4 KB
  • Android登录界面之用户数据保存+服务器上传(一)
            
    
    博客分类: Android项目实战 登录注册界面设计dp px转换AndroidMVC模式 
  • 大小: 10.4 KB
  • Android登录界面之用户数据保存+服务器上传(一)
            
    
    博客分类: Android项目实战 登录注册界面设计dp px转换AndroidMVC模式 
  • 大小: 25.4 KB
  • Android登录界面之用户数据保存+服务器上传(一)
            
    
    博客分类: Android项目实战 登录注册界面设计dp px转换AndroidMVC模式 
  • 大小: 2.3 KB
  • Android登录界面之用户数据保存+服务器上传(一)
            
    
    博客分类: Android项目实战 登录注册界面设计dp px转换AndroidMVC模式 
  • 大小: 5.8 KB
  • Android登录界面之用户数据保存+服务器上传(一)
            
    
    博客分类: Android项目实战 登录注册界面设计dp px转换AndroidMVC模式 
  • 大小: 29 KB