`

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);

	}
}

 登录的布局:



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

 

 

 

  • 大小: 6.4 KB
  • 大小: 10.4 KB
  • 大小: 25.4 KB
  • 大小: 2.3 KB
  • 大小: 5.8 KB
  • 大小: 29 KB
分享到:
评论

相关推荐

    Android涂鸦上传到服务器

    在Android开发中,实现“涂鸦上传到服务器”的功能涉及到多个技术点,包括用户界面设计、图像处理、网络通信以及服务器端的接口处理。以下是对这些知识点的详细说明: 1. **用户界面设计**:首先,我们需要创建一个...

    Android二手交易客户端+服务器端

    在本项目中,我们讨论的是一个完整的Android二手交易系统,包括客户端、服务器端以及数据库的实现。这个系统为用户提供了一个方便的平台,他们可以在这个平台上买卖二手物品,从而促进资源的有效利用。 首先,从...

    Android实现注册登录头像上传等服务器端

    服务器端接收到请求后,通常会将接收到的二进制数据保存到特定的目录或者云存储服务中,并返回一个唯一的URL,这个URL可以用于在客户端展示头像。 在服务器端,Python是一种常见的编程语言,文件处理和网络通信库...

    app打印日志保存到手机上传服务器

    本文将详细讲解如何在Android应用中实现“app打印日志保存到手机并上传服务器”的功能,以提高调试效率和用户体验。 首先,我们需要了解Android系统中的日志系统。Android提供了Log类,它包含了一些静态方法,如`...

    android 登陆、提交数据或加载数据时提示页面

    在Android应用开发中,用户界面(UI)的交互体验至关重要,尤其是涉及到登录、提交数据以及加载数据等操作。这些操作通常涉及到网络通信、数据持久化、异步处理等多个技术领域。下面将根据提供的标题和描述,详细...

    android拍摄视频并上传到PHP服务器

    在Android平台上,开发一款应用允许用户拍摄视频并将其上传到PHP服务器是一项常见的需求。这个过程涉及到多个技术点,包括Android的多媒体API、网络编程以及服务器端的文件接收处理。以下是对这些关键知识点的详细...

    Android应用源码之android拍摄视频并上传到PHP服务器.zip

    在本压缩包中,我们关注的是一个Android应用的源码示例,该示例展示了如何在Android设备上拍摄视频,并将录制的视频上传至PHP服务器。这个实例对于开发者,特别是那些正在学习Android应用开发的人来说,是非常有价值...

    Android客户端+web服务端实现图片上传到服务器

    在本项目中,"Android客户端+web服务端实现图片上传到服务器"是一个综合性的实践案例,涵盖了移动应用开发和Web服务交互的关键技术。这个项目旨在教你如何通过Android客户端应用程序将拍摄的照片上传到服务器,然后...

    Android图片上传服务器

    在Android应用开发中,图片上传至服务器是一项常见的需求,尤其在社交、电商或者任何需要用户分享内容的应用中。本文将详细讲解如何实现Android图片上传至服务器的完整过程,结合一个名为"UploadPhotoDemo"的示例...

    android (可发送 信息+语音+文件)实例.rar

    在Android平台上,开发一个能够发送信息、语音以及文件的应用是一个常见的需求,这涉及到多个关键的技术领域,包括网络通信、多媒体处理、文件管理等。在这个"android (可发送 信息+语音+文件)实例"中,我们可以深入...

    android文件上传(包括android端和服务器端)

    在Android平台上进行文件上传涉及到多个技术层面,包括客户端(Android端)的文件操作、网络通信以及服务器端的数据处理。下面将详细阐述这个过程中的关键知识点。 1. **Android端文件操作**: - **文件选择**:...

    Android客户端与服务器数据交互流程样本.doc

    8. **状态管理**:为了跟踪用户的登录状态和个性化信息,Android客户端可能需要保存服务器返回的Token或Session ID,并在后续请求中携带,以维持会话状态。 9. **错误处理**:网络请求可能会遇到各种问题,如网络...

    Android利用webservice上传图片至服务器_Android端

    在Android开发中,将图片上传到服务器是一项常见的需求,尤其在社交、电商或者任何需要用户分享内容的应用中。本教程将详细介绍如何在Android应用中利用Web Service(通常为SOAP协议)来实现图片上传功能。 首先,...

    android录音上传到服务器,上传使用AsyncTask异步任务.zip

    在Android应用开发中,录音和将录音文件上传到服务器是一项常见的功能。这个压缩包文件"android录音上传到服务器,上传使用AsyncTask异步任务.zip"包含了一个实现这一功能的源码示例。以下是对其中涉及的关键知识点...

    android文件上传控件

    在Android应用开发中,文件上传是一项常见的功能,尤其在社交、云存储或协作类应用中。本篇将详细讲解如何在Android中实现文件上传,并结合“亲测可用”的控件来探讨具体实践。 首先,我们需要了解Android中的文件...

    android_调用摄像头拍摄一段视频并上传到服务器

    在Android平台上,调用摄像头拍摄视频并将其上传到服务器是一项常见的功能,特别是在移动应用开发中。这个过程涉及多个步骤,包括请求相机权限、启动相机、录制视频、保存视频到本地、选择合适的上传策略以及处理...

    android拍摄视频并上传到PHP服务器-IT计算机-毕业设计.zip

    在Android平台上,开发一款能够拍摄视频并将其上传到PHP服务器的应用是常见的移动开发任务,尤其在毕业设计项目中。这个项目涉及到多个技术领域,包括Android SDK的使用、多媒体处理、网络编程以及服务器端的PHP开发...

    android java 客户端和服务器的数据交互

    在Android应用开发中,Java客户端与服务器的数据交互是不可或缺的一部分,它使得应用程序能够获取服务器上的数据,更新用户界面,或者发送用户数据到服务器进行存储或处理。本篇将深入探讨这个主题,涵盖基本概念、...

    Android网络编程之客户端服务器端的交互之上传下载解压文件

    服务器需要解析接收到的请求,根据请求类型(GET或POST)执行相应操作,如返回数据、保存上传的文件等。 在整个过程中,需要注意的是错误处理和异常捕获,确保在网络不稳定或者服务器出现问题时,应用能够优雅地...

    Android网盘系统(带servlet服务器)

    对于Android平台,构建一个完善的网盘系统需要结合服务器端的技术支持,如Servlet服务器,以及客户端的用户体验设计,如用户登录、文件操作和进度显示。本篇文章将详细解析如何利用Apache-Upload组件搭建服务端,并...

Global site tag (gtag.js) - Google Analytics