用户登录记住密码

来源:互联网 发布:上海cnc编程招聘信息 编辑:程序博客网 时间:2024/05/01 14:10

用户登录记住密码

此次项目任务,首先要实现登录界面的显示,然后,是其在登录时,当用户选中了记住密码复选框,并成功登录一次之后,这个时候如果再重新启动登录界面,之前输入的用户名和密码就会显示在文本框中。
运行结果应如下图:
这里写图片描述
一、登录界面的布局
Step1:把完成项目所需的三张图片命名(deer.png)(icon_pass.png)(icon_user.png),并放入drawable文件夹下。
Step2:在drawable文件夹下,创建logintop_roundbg.xml

<?xml version="1.0" encoding="utf-8"?><shape xmlns:android="http://schemas.android.com/apk/res/android" android:shape="rectangle">    <corners android:radius="10dp"></corners>    <solid android:color="#55FFFFFF"></solid></shape>

Step3:在drawable文件夹下,创建btn_select.xml

<?xml version="1.0" encoding="utf-8"?><selector xmlns:android="http://schemas.android.com/apk/res/android">    <item android:drawable="@drawable/btn_shape" android:state_pressed="false"></item>    <item android:drawable="@drawable/btn_shape_after" android:state_pressed="true"></item></selector>

创建btn_shape.xml文件

<?xml version="1.0" encoding="utf-8"?><shape xmlns:android="http://schemas.android.com/apk/res/android">    <solid android:color="#FF72CAE1"></solid>    <corners android:radius="10dp"></corners></shape>

创建btn_shape_after.xml文件

<?xml version="1.0" encoding="utf-8"?><shape xmlns:android="http://schemas.android.com/apk/res/android">    <solid android:color="#87ceaf"></solid>    <corners android:radius="10dp"></corners></shape>

Step4:
(1)在layout文件夹下,定义login_top.xml文件

<?xml version="1.0" encoding="utf-8"?><RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"    android:layout_width="match_parent"    android:layout_height="wrap_content"    android:padding="@dimen/activity_horizontal_margin"    android:background="@drawable/logintop_roundbg">    <EditText        android:id="@+id/etName"        android:layout_width="match_parent"        android:layout_height="wrap_content"        android:background="@android:drawable/edit_text"        android:drawableLeft="@drawable/icon_user"        android:drawablePadding="10dp"        android:ems="10"        android:hint="@string/etName">        <requestFocus />    </EditText>    <EditText        android:id="@+id/etPassword"        android:layout_width="match_parent"        android:layout_height="wrap_content"        android:layout_below="@id/etName"        android:background="@android:drawable/edit_text"        android:drawableLeft="@drawable/icon_pass"        android:drawablePadding="10dp"        android:ems="10"        android:hint="@string/etPass"        android:inputType="textPassword">        <requestFocus />    </EditText>    <LinearLayout        android:layout_width="match_parent"        android:layout_height="wrap_content"        android:layout_below="@id/etPassword">        <CheckBox            android:text="记住密码"            android:layout_width="0dp"            android:layout_height="wrap_content"            android:id="@+id/cbIsRememberPass"            android:textSize="20sp"            android:layout_weight="1" />        <Button            android:layout_width="0dp"            android:layout_height="wrap_content"            android:layout_weight="1"            android:layout_marginLeft="10dp"            android:background="@drawable/btn_select"            android:onClick="login"            android:text="@string/btnLogin" />    </LinearLayout></RelativeLayout>

(2)定义activity_login.xml文件

<?xml version="1.0" encoding="utf-8"?><RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"    xmlns:app="http://schemas.android.com/apk/res-auto"    xmlns:tools="http://schemas.android.com/tools"    android:id="@+id/activity_login"    android:layout_width="match_parent"    android:layout_height="match_parent"    android:paddingBottom="@dimen/activity_vertical_margin"    android:paddingLeft="@dimen/activity_horizontal_margin"    android:paddingRight="@dimen/activity_horizontal_margin"    android:paddingTop="@dimen/activity_vertical_margin"    android:background="@drawable/loginbg"    tools:context="com.example.administrator.a03lab6_3case_login.LoginActivity">    <include layout="@layout/login_top"></include>    <ImageView        android:layout_width="wrap_content"        android:layout_height="wrap_content"        app:srcCompat="@drawable/deer"        android:id="@+id/imageView"        android:layout_alignParentBottom="true"        android:layout_alignParentLeft="true"        android:layout_alignParentStart="true"        android:layout_marginLeft="127dp"        android:layout_marginStart="127dp" /></RelativeLayout>

Step5:在drawable文件夹下,用loginbg.xml文件来描述背景图片,代码如下

<?xml version="1.0" encoding="utf-8"?><shape xmlns:android="http://schemas.android.com/apk/res/android">    <gradient        android:startColor="#FFACDAE5"        android:endColor="#FF72CAE1"        android:angle="45"        /></shape>

Step6:在values文件下的strings.xml中输入代码,如下

<resources>    <string name="app_name">Case_Login</string>    <string name="etName">请输入账号</string>    <string name="etPass">请输入密码</string>    <string name="btnLogin">登录</string></resources>

二、用户记住密码登录
Step1:配置LoginActivity程序,代码如下

package com.example.administrator.a03lab6_3case_login;import android.content.Context;import android.content.Intent;import android.content.SharedPreferences;import android.support.v7.app.AppCompatActivity;import android.os.Bundle;import android.view.View;import android.view.inputmethod.EditorInfo;import android.widget.CheckBox;import android.widget.Checkable;import android.widget.EditText;import android.widget.Toast;public class LoginActivity extends AppCompatActivity {    private EditText etName;    private EditText etPassword;    private CheckBox cbIsRememberPass;    private SharedPreferences sharedPreferences;    @Override    protected void onCreate(Bundle savedInstanceState) {        super.onCreate(savedInstanceState);        setContentView(R.layout.activity_login);        initViews();        sharedPreferences=getSharedPreferences("rememberpassword",Context.MODE_PRIVATE);        boolean isRemember=sharedPreferences.getBoolean("rememberpassword",false);        if (isRemember){            String name=sharedPreferences.getString("name","");            String password=sharedPreferences.getString("password","");            etName.setText(name);            etPassword.setText(password);            cbIsRememberPass.setChecked(true);        }    }    private void initViews(){        etName=(EditText)findViewById(R.id.etName);        etPassword=(EditText)findViewById(R.id.etPassword);        cbIsRememberPass=(CheckBox)findViewById(R.id.cbIsRememberPass);    }    public void login(View view){        String name=etName.getText().toString();        String password=etPassword.getText().toString();        if ("admin".equals(name)&&"123456".equals(password)) {            SharedPreferences.Editor editor = sharedPreferences.edit();            if (cbIsRememberPass.isChecked()) {                editor.putBoolean("rememberpassword", true);                editor.putString("name", name);                editor.putString("password", password);            } else {                editor.clear();            }            editor.commit();            Intent intent = new Intent(this, MainActivity.class);            startActivity(intent);            finish();        }else{            Toast.makeText(this,"账号或密码有误",Toast.LENGTH_LONG).show();        }    }}

Step2:创建MainActivity文件,生成activity_main.xml文件
(1)配置MainActivity程序,代码如下

package com.example.administrator.a03lab6_3case_login;import android.support.v7.app.AppCompatActivity;import android.os.Bundle;public class MainActivity extends AppCompatActivity {    @Override    protected void onCreate(Bundle savedInstanceState) {        super.onCreate(savedInstanceState);        setContentView(R.layout.activity_main);    }}

(2)配置activity_main.xml文件,代码如下

<?xml version="1.0" encoding="utf-8"?><RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"    xmlns:tools="http://schemas.android.com/tools"    android:id="@+id/activity_main"    android:layout_width="match_parent"    android:layout_height="match_parent"    android:paddingBottom="@dimen/activity_vertical_margin"    android:paddingLeft="@dimen/activity_horizontal_margin"    android:paddingRight="@dimen/activity_horizontal_margin"    android:paddingTop="@dimen/activity_vertical_margin"    tools:context="com.example.administrator.a03lab6_3case_login.MainActivity">    <TextView        android:text="Welcome you"        android:layout_width="wrap_content"        android:layout_height="wrap_content"        android:layout_centerVertical="true"        android:layout_centerHorizontal="true"        android:textSize="40sp"        android:layout_marginTop="263dp"        android:id="@+id/textView" /></RelativeLayout>

Step3:打开工具栏中的Tools,找到如下图所在的文件
这里写图片描述
在rememberpassword.xml文件中的代码如下

<?xml version=’1.0’ encoding=’utf-8’ standalone=’yes’?><map<string name= "password">123456</string><boolean name= "rememberpassword" value="ture"/ ><string name= "name">admin</string></map>

三、最后创建完的布局文件列表如图所示:
这里写图片描述
四、最后的运行结果图如下
这里写图片描述
这里写图片描述
这里写图片描述

0 0
原创粉丝点击