纵有疾风起
人生不言弃

教育系统APP(四)

“我”的模块
掌握修改密码功能的开发,实现用户密码的修改
掌握设置密保功能的开发,并且通过密保可以找回用户密码

挑战任务
初次打开页面都是Fragment_1,请修改相关代码,让初始打开的页面为Fragment_3,别忘了底部导航栏也要变颜色哦

解决方案
改MainActivity.java即可

package cn.edu.gdmec.android.boxuegu.activity;import android.content.pm.ActivityInfo;import android.graphics.Color;import android.os.Bundle;import android.support.v4.app.FragmentActivity;import android.view.View;import android.widget.ImageView;import android.widget.LinearLayout;import android.widget.RelativeLayout;import android.widget.TextView;import cn.edu.gdmec.android.boxuegu.R;import cn.edu.gdmec.android.boxuegu.fragment.CourseFragment;import cn.edu.gdmec.android.boxuegu.fragment.ExercisesFragment;import cn.edu.gdmec.android.boxuegu.fragment.MyinfoFragment;/*任务在主界面的Hello World位置显示:用户名+“登录成功”*/public class MainActivity extends FragmentActivity implements View.OnClickListener{    private RelativeLayout main_body;    private TextView bottom_bar_text_course;    private ImageView bottom_bar_image_course;    private RelativeLayout bottom_bar_course_btn;    private TextView bottom_bar_text_exercises;    private ImageView bottom_bar_image_exercises;    private RelativeLayout bottom_bar_exercises_btn;    private TextView bottom_bar_text_myinfo;    private ImageView bottom_bar_image_myinfo;    private RelativeLayout bottom_bar_myinfo_btn;    private LinearLayout main_bottom_bar;    @Override    protected void onCreate(Bundle savedInstanceState) {        super.onCreate(savedInstanceState);        setContentView(R.layout.activity_main);        initView();        setRequestedOrientation(ActivityInfo.SCREEN_ORIENTATION_PORTRAIT);        //把Fragment加到Activity里的代码如下       /* FragmentManager manager = getSupportFragmentManager();        FragmentTransaction transaction = manager.beginTransaction();        transaction.add(R.id.main_body,new CourseFragment()).commit();*/       setMain();    }    private void setMain() {        this.getSupportFragmentManager().beginTransaction().add(R.id.main_body,new MyinfoFragment()).commit();        setSelectStatus(2);    }    private void setSelectStatus(int index) {        switch (index){            case 0:                bottom_bar_image_course.setImageResource(R.drawable.main_course_icon_selected);                bottom_bar_text_course.setTextColor(Color.parseColor("#0097F7"));                bottom_bar_text_exercises.setTextColor(Color.parseColor("#666666"));                bottom_bar_text_myinfo.setTextColor(Color.parseColor("#666666"));                bottom_bar_image_exercises.setImageResource(R.drawable.main_exercises_icon);                bottom_bar_image_myinfo.setImageResource(R.drawable.main_my_icon);                break;            case 1:                bottom_bar_image_exercises.setImageResource(R.drawable.main_exercises_icon_selected);                bottom_bar_text_exercises.setTextColor(Color.parseColor("#0097F7"));                bottom_bar_text_course.setTextColor(Color.parseColor("#666666"));                bottom_bar_text_myinfo.setTextColor(Color.parseColor("#666666"));                bottom_bar_image_course.setImageResource(R.drawable.main_course_icon);                bottom_bar_image_myinfo.setImageResource(R.drawable.main_my_icon);                break;            case 2:                bottom_bar_image_myinfo.setImageResource(R.drawable.main_my_icon_selected);                bottom_bar_text_myinfo.setTextColor(Color.parseColor("#0097F7"));                bottom_bar_text_course.setTextColor(Color.parseColor("#666666"));                bottom_bar_text_exercises.setTextColor(Color.parseColor("#666666"));                bottom_bar_image_exercises.setImageResource(R.drawable.main_exercises_icon);                bottom_bar_image_course.setImageResource(R.drawable.main_course_icon);                break;        }    }    private void initView() {        main_body = findViewById(R.id.main_body);        bottom_bar_text_course = findViewById(R.id.bottom_bar_text_course);        bottom_bar_image_course = findViewById(R.id.bottom_bar_image_course);        bottom_bar_course_btn = findViewById(R.id.bottom_bar_course_btn);        bottom_bar_text_exercises = findViewById(R.id.bottom_bar_text_exercises);        bottom_bar_image_exercises = findViewById(R.id.bottom_bar_image_exercises);        bottom_bar_exercises_btn = findViewById(R.id.bottom_bar_exercises_btn);        bottom_bar_text_myinfo = findViewById(R.id.bottom_bar_text_myinfo);        bottom_bar_image_myinfo = findViewById(R.id.bottom_bar_image_myinfo);        bottom_bar_myinfo_btn = findViewById(R.id.bottom_bar_myinfo_btn);        main_bottom_bar = findViewById(R.id.main_bottom_bar);        bottom_bar_course_btn.setOnClickListener(this);        bottom_bar_exercises_btn.setOnClickListener(this);        bottom_bar_myinfo_btn.setOnClickListener(this);    }    @Override    public void onClick(View v) {        switch (v.getId()){            case R.id.bottom_bar_course_btn:                getSupportFragmentManager().beginTransaction().add(R.id.main_body,new CourseFragment()).commit();                setSelectStatus(0);                break;            case R.id.bottom_bar_exercises_btn:                getSupportFragmentManager().beginTransaction().add(R.id.main_body,new ExercisesFragment()).commit();                setSelectStatus(1);                break;            case R.id.bottom_bar_myinfo_btn:                getSupportFragmentManager().beginTransaction().add(R.id.main_body,new MyinfoFragment()).commit();                setSelectStatus(2);                break;        }    }}

APP(四)
博学谷项目“我”的模块

学习目标
掌握修改密码功能的开发,实现用户密码的修改;
掌握设置密保功能的开发,并且通过密保可以找回用户密码。

项目实操
“我”的界面
设置
修改密码
设置密保和找回密码
任务实施
修复fragment的小BUG
修改密保设置页面
优化找回密码

“我”的模块主要时以设置用户以及保证用户安全为主。当用户登录成功后,可以修改密码以及设置密保,且只有设置过密保的帐户才可以找回密码。

“我”的界面
首先是资源图片,“我”的界面要用到的图片有myinfo_login_bg、course_history_icon、iv_right_arrow、myinfo_setting_icon

老样子,将它们放到drawable下

教育系统APP(四)插图
file

然后是布局代码,在我们上一次课创的fragment_myinfo里加上代码fragment_myinfo.xml

<?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:background="@android:color/white"    android:orientation="vertical">    <LinearLayout        android:id="@+id/ll_head"        android:layout_width="match_parent"        android:layout_height="240dp"        android:background="@drawable/myinfo_login_bg"        android:orientation="vertical">        <ImageView            android:id="@+id/iv_head_icon"            android:layout_width="70dp"            android:layout_height="70dp"            android:layout_gravity="center_horizontal"            android:layout_marginTop="75dp"            android:src="@drawable/default_icon" />        <TextView            android:id="@+id/tv_user_name"            android:layout_width="wrap_content"            android:layout_height="wrap_content"            android:layout_gravity="center_horizontal"            android:layout_marginTop="10dp"            android:text="点击登录"            android:textColor="@android:color/white"            android:textSize="16sp" />    </LinearLayout>    <View        android:layout_width="match_parent"        android:layout_height="1dp"        android:layout_marginTop="20dp"        android:background="#E3E3E3" />    <RelativeLayout        android:id="@+id/rl_course_history"        android:layout_width="match_parent"        android:layout_height="50dp"        android:layout_marginLeft="10dp"        android:layout_marginRight="10dp"        android:background="#F7F8F8"        android:gravity="center_vertical">        <ImageView            android:id="@+id/iv_course_history_icon"            android:layout_width="20dp"            android:layout_height="20dp"            android:layout_centerVertical="true"            android:layout_marginLeft="25dp"            android:src="@drawable/course_history_icon" />        <TextView            android:layout_width="wrap_content"            android:layout_height="wrap_content"            android:layout_centerVertical="true"            android:layout_marginLeft="25dp"            android:layout_toRightOf="@id/iv_course_history_icon"            android:text="播放记录"            android:textColor="#A3A3A3"            android:textSize="16sp" />        <ImageView            android:layout_width="15dp"            android:layout_height="15dp"            android:layout_alignParentRight="true"            android:layout_centerVertical="true"            android:layout_marginRight="25dp"            android:src="@drawable/iv_right_arrow" />    </RelativeLayout>    <View        android:layout_width="match_parent"        android:layout_height="1dp"        android:background="#E3E3E3" />    <RelativeLayout        android:id="@+id/rl_setting"        android:layout_width="match_parent"        android:layout_height="50dp"        android:layout_marginLeft="10dp"        android:layout_marginRight="10dp"        android:background="#F7F8F8"        android:gravity="center_vertical">        <ImageView            android:id="@+id/iv_userInfo_icon"            android:layout_width="20dp"            android:layout_height="20dp"            android:layout_centerVertical="true"            android:layout_marginLeft="25dp"            android:src="@drawable/myinfo_setting_icon" />        <TextView            android:layout_width="wrap_content"            android:layout_height="wrap_content"            android:layout_centerVertical="true"            android:layout_marginLeft="25dp"            android:layout_toRightOf="@id/iv_userInfo_icon"            android:text="设置"            android:textColor="#A3A3A3"            android:textSize="16sp" />        <ImageView            android:layout_width="15dp"            android:layout_height="15dp"            android:layout_alignParentRight="true"            android:layout_centerVertical="true"            android:layout_marginRight="25dp"            android:src="@drawable/iv_right_arrow" />    </RelativeLayout>    <View        android:layout_width="match_parent"        android:layout_height="1dp"        android:background="#E3E3E3" /></LinearLayout>

修改完成后,我们试着运行一下,点击底部导航栏中的“我”,一个毫无互动的页面就出来啦。

“我”的界面能显示后,我们来写个工具类。
由于项目多次用到sharedPreferences共享参数去存储用户的登录状态或清除登录状态,“我”的界面也要求用到读取用户姓名的方法,所以我们干脆把这三个方法都扔到AnalysisUtils里面吧。
在Utils包中新建一个Java类,名为AnalysisUtils。

创建完成后,我们在里面写上readLoginStatus()、clearLoginStatus()、
readLoginUserName()三个方法。

AnalysisUtils.java

package cn.edu.gdmec.android.boxuegu.utils;import android.content.Context;import android.content.SharedPreferences;public class AnalysisUtils {    //读取用户名    public static String readLoginUserName(Context context){        SharedPreferences sharedPreferences = context.getSharedPreferences("loginInfo",Context.MODE_PRIVATE);        String userName=sharedPreferences.getString("loginUserName","");        return userName;    }    //读取登录状态    public static boolean readLoginStatus(Context context){        SharedPreferences sharedPreferences = context.getSharedPreferences("loginInfo",Context.MODE_PRIVATE);        boolean isLogin=sharedPreferences.getBoolean("isLogin",false);        return isLogin;    }    //清除登录状态    public static void cleanLoginStatus(Context context){        SharedPreferences sharedPreferences = context.getSharedPreferences("loginInfo",Context.MODE_PRIVATE);        SharedPreferences.Editor editor = sharedPreferences.edit();        editor.putBoolean("isLogin",false);        editor.putString("loginUserName","");        editor.commit();    }}

以后我们要用到这些方法的时候,调用一下就好啦。
写完工具类后,我们来继续完善“我”的页面的代码。
给MyinfoFragment加上View.OnClickListener接口。

public class MyinfoFragment extends Fragment implements View.OnClickListener{

在冒红的地方alt+回车生成onClick()方法,把要响应的id加上去。

MyinfoFragment.java

@Override    public void onClick(View v) {        switch (v.getId()){            case R.id.ll_head:                break;            case R.id.rl_course_history:                break;            case R.id.rl_setting:                break;        }    }

别忘了监听器。

MyinfoFragment.java

    @Override    public void onViewCreated(View view, Bundle savedInstanceState) {        super.onViewCreated(view, savedInstanceState);        llHead = (LinearLayout) view.findViewById(R.id.ll_head);        ivHeadIcon = (ImageView) view.findViewById(R.id.iv_head_icon);        tvUserName = (TextView) view.findViewById(R.id.tv_user_name);        rlCourseHistory = (RelativeLayout) view.findViewById(R.id.rl_course_history);        ivCourseHistoryIcon = (ImageView) view.findViewById(R.id.iv_course_history_icon);        rlSetting = (RelativeLayout) view.findViewById(R.id.rl_setting);        ivUserInfoIcon = (ImageView) view.findViewById(R.id.iv_userInfo_icon);        llHead.setOnClickListener(this);        rlCourseHistory.setOnClickListener(this);        rlSetting.setOnClickListener(this);    }

“我”的界面的头像部分,要实现两个功能

打开“我”的界面后要判断是否已登录,已登录显示用户名,未登录显示“点击登陆”。
头像部分点击后,会判断是否登录,如果登录了,则跳转到个人资料界面,如果没登录,则跳转到login页面。
先来完成第一个功能
我们在onViewCreate()里写个if else判断语句,根据当前登录状态来显示同像下相应的文本。
判断的内容就可以调用我们刚才写过的工具类啦。

MyinfoFragment.java

    @Override    public void onViewCreated(View view, Bundle savedInstanceState) {        super.onViewCreated(view, savedInstanceState);        llHead = (LinearLayout) view.findViewById(R.id.ll_head);        ivHeadIcon = (ImageView) view.findViewById(R.id.iv_head_icon);        tvUserName = (TextView) view.findViewById(R.id.tv_user_name);        rlCourseHistory = (RelativeLayout) view.findViewById(R.id.rl_course_history);        ivCourseHistoryIcon = (ImageView) view.findViewById(R.id.iv_course_history_icon);        rlSetting = (RelativeLayout) view.findViewById(R.id.rl_setting);        ivUserInfoIcon = (ImageView) view.findViewById(R.id.iv_userInfo_icon);        if (AnalysisUtils.readLoginStatus(getActivity())){            tvUserName.setText(AnalysisUtils.readLoginUserName(getActivity()));        }else {            tvUserName.setText("点击登录");        }        llHead.setOnClickListener(this);        rlCourseHistory.setOnClickListener(this);        rlSetting.setOnClickListener(this);    }

然后在onClick()方法里给头像部分的点击以及其他按钮加上判断。

MyinfoFragment.java

    @Override    public void onClick(View v) {        switch (v.getId()){            case R.id.ll_head:                if (AnalysisUtils.readLoginStatus(getActivity())){                    //跳转到个人资料界面                }else {                    //跳转到登录界面                    Intent intent = new Intent(getActivity(), LoginActivity.class);                    getActivity().startActivityForResult(intent,1);                }                break;            case R.id.rl_course_history:                if (AnalysisUtils.readLoginStatus(getActivity())){                    //跳转到播放记录页面                }else {                    Toast.makeText(getActivity(),"您未登录,请先登录",Toast.LENGTH_SHORT).show();                }                break;            case R.id.rl_setting:                if (AnalysisUtils.readLoginStatus(getActivity())){                    //跳转到设置界面                }else {                    Toast.makeText(getActivity(),"您未登录,请先登录",Toast.LENGTH_SHORT).show();                }                break;        }    }

注意:未登录时,点击登陆打开登陆页面后,需要MainActivity更新状态并显示,所以用startActivityForResult()方法打开。老样子,这边用startActivityForResult()打开,MainActivity就要加上onActivityForResult()方法来执行响应。

在MainActivity里按ctrl+O,再打“onActivity”几个字母,找到onActivityForResult方法,点击生成代码。

    @Override    protected void onActivityResult(int requestCode, int resultCode, Intent data) {        super.onActivityResult(requestCode, resultCode, data);    }

再给它加上代码:判断从LoginActivity传过来登陆状态,并执行响应动作。

MainActivity.java

    @Override    protected void onActivityResult(int requestCode, int resultCode, Intent data) {        super.onActivityResult(requestCode, resultCode, data);        if (data!=null){            boolean isLogin=data.getBooleanExtra("isLogin",false);            if (isLogin){                setSelectStatus(0);            }            else {                setSelectStatus(2);            }        }    }

Ok,为了方便检验效果,我们给MainActivity加上退出清除登陆状态的方法。连续点击返回两次则退出,两次点击间隔超过2秒则提示再按一次退出。

MainActivity.java

protected long exitTime;     @Override    public boolean onKeyDown(int keyCode, KeyEvent event) {        if (keyCode == KeyEvent.KEYCODE_BACK && event.getAction() == KeyEvent.ACTION_DOWN) {            if ((System.currentTimeMillis() - exitTime) > 2000) {                Toast.makeText(MainActivity.this, "再按一次退出博学谷", Toast.LENGTH_SHORT).show();                exitTime = System.currentTimeMillis();            } else {                this.finish();                if (AnalysisUtils.readLoginStatus(this)) {                    AnalysisUtils.cleanLoginStatus(this);                }                System.exit(0);            }            return true;        }        return super.onKeyDown(keyCode, event);    }

然后我们运行下程序,登陆完成后,“我”的界面应该显示用户名。
这时候大家会发现,点击“点击登陆”,登陆完成后,显示的是下图的页面,再点一下底部导航栏后,又正常显示了。但是完成上一节任务的会不一样哦~

这就是常见的fragment刷新问题啦,把它当作一个小BUG,做为今天的“任务实施”吧,解决它。

设置
接下来我们来做设置界面。
新建一个布局文件,名为activity_setting。

加上布局代码。
activity_setting.xml

<?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:background="@android:color/white"    android:orientation="vertical">    <!--这个标题显示 设置-->    <include layout="@layout/main_title_bar" />    <View        android:layout_width="match_parent"        android:layout_height="1dp"        android:layout_marginTop="15dp"        android:background="#E3E3E3" />    <RelativeLayout        android:id="@+id/rl_modify_psw"        android:layout_width="match_parent"        android:layout_height="50dp"        android:background="#F7F8F8"        android:gravity="center_vertical"        android:paddingLeft="10dp"        android:paddingRight="10dp">        <TextView            android:layout_width="wrap_content"            android:layout_height="wrap_content"            android:layout_centerVertical="true"            android:layout_marginLeft="25dp"            android:text="修改密码"            android:textColor="#A3A3A3"            android:textSize="16sp" />        <ImageView            android:layout_width="15dp"            android:layout_height="15dp"            android:layout_alignParentRight="true"            android:layout_centerVertical="true"            android:paddingRight="25dp"            android:src="@drawable/iv_right_arrow" />    </RelativeLayout>    <View        android:layout_width="match_parent"        android:layout_height="1dp"        android:background="#E3E3E3" />    <RelativeLayout        android:id="@+id/rl_security_setting"        android:layout_width="match_parent"        android:layout_height="50dp"        android:background="#F7F8F8"        android:gravity="center_vertical"        android:paddingLeft="10dp"        android:paddingRight="10dp">        <TextView            android:layout_width="wrap_content"            android:layout_height="wrap_content"            android:layout_centerVertical="true"            android:layout_marginLeft="25dp"            android:text="设置密保"            android:textColor="#A3A3A3"            android:textSize="16sp" />        <ImageView            android:layout_width="15dp"            android:layout_height="15dp"            android:layout_alignParentRight="true"            android:layout_centerVertical="true"            android:paddingRight="25dp"            android:src="@drawable/iv_right_arrow" />    </RelativeLayout>    <View        android:layout_width="match_parent"        android:layout_height="1dp"        android:background="#E3E3E3" />    <View        android:layout_width="match_parent"        android:layout_height="1dp"        android:layout_marginTop="15dp"        android:background="#E3E3E3" />    <RelativeLayout        android:id="@+id/rl_exit_login"        android:layout_width="match_parent"        android:layout_height="50dp"        android:background="#F7F8F8"        android:gravity="center_vertical"        android:paddingLeft="10dp"        android:paddingRight="10dp">        <TextView            android:layout_width="wrap_content"            android:layout_height="wrap_content"            android:layout_centerVertical="true"            android:layout_marginLeft="25dp"            android:text="退出登录"            android:textColor="#A3A3A3"            android:textSize="16sp" />    </RelativeLayout>    <View        android:layout_width="match_parent"        android:layout_height="1dp"        android:background="#E3E3E3" /></LinearLayout>

创建一个新activity
给tv_main_title设个文本。给title_bar加个背景。加上View.onClickListener接口。Alt+回车生成onClick()代码。在onClick()中加上设置界面要用到的几个按钮。给几个按钮加上监听器。

SettingActivity.java

package cn.edu.gdmec.android.boxuegu.activity;import android.app.Activity;import android.content.Intent;import android.graphics.Color;import android.os.Bundle;import android.view.View;import android.widget.RelativeLayout;import android.widget.TextView;import android.widget.Toast;import cn.edu.gdmec.android.boxuegu.R;import cn.edu.gdmec.android.boxuegu.utils.AnalysisUtils;public class SettingActivity extends Activity implements View.OnClickListener{    private TextView tv_back;    private TextView tv_main_title;    private TextView tv_save;    private RelativeLayout title_bar;    private RelativeLayout rl_modify_psw;    private RelativeLayout rl_security_setting;    private RelativeLayout rl_exit_login;    public static SettingActivity instance=null;    @Override    protected void onCreate(Bundle savedInstanceState) {        super.onCreate(savedInstanceState);        setContentView(R.layout.activity_setting);        instance=this;        initView();    }    private void initView(){        tv_back=findViewById(R.id.tv_back);        tv_main_title=findViewById(R.id.tv_main_title);        tv_save=findViewById(R.id.tv_save);        title_bar=findViewById(R.id.title_bar);        rl_modify_psw=findViewById(R.id.rl_modify_psw);        rl_security_setting=findViewById(R.id.rl_security_setting);        rl_exit_login=findViewById(R.id.rl_exit_login);        tv_main_title.setText("设置");        title_bar.setBackgroundColor(Color.parseColor("#30B4FF"));        tv_back.setOnClickListener(this);        rl_modify_psw.setOnClickListener(this);        rl_security_setting.setOnClickListener(this);        rl_exit_login.setOnClickListener(this);    }    @Override    public void onClick(View v) {        switch (v.getId()){            case R.id.tv_back:                SettingActivity.this.finish();                break;            case R.id.rl_modify_psw:                //修改密码界面                break;            case R.id.rl_security_setting:                //设置密保界面                break;            case R.id.rl_exit_login:                //退出登录,即清除登录状态                Toast.makeText(this,"退出登录成功",Toast.LENGTH_SHORT).show();                AnalysisUtils.cleanLoginStatus(this);                Intent data=new Intent();                data.putExtra("isLogin",false);                setResult(RESULT_OK,data);                finish();                break;        }    }}

MyinfoFragmrnt.java里把跳转代码加上。

    @Override    public void onClick(View v) {        switch (v.getId()){            case R.id.ll_head:                if (AnalysisUtils.readLoginStatus(getActivity())){                    //跳转到个人资料界面                }else {                    //跳转到登录界面                }                break;            case R.id.rl_course_history:                if (AnalysisUtils.readLoginStatus(getActivity())){                    //跳转到播放记录页面                }else {                    Toast.makeText(getActivity(),"您未登录,请先登录",Toast.LENGTH_SHORT).show();                }                break;            case R.id.rl_setting:                if (AnalysisUtils.readLoginStatus(getActivity())){                    //跳转到设置界面                    Intent intent=new Intent(getActivity(), SettingActivity.class);                    getActivity().startActivityForResult(intent,1);                }else {                    Toast.makeText(getActivity(),"您未登录,请先登录",Toast.LENGTH_SHORT).show();                }                break;        }    }

别忘了到AndroidManifest.xml声明下SettingActivity,运行程序,在“我”的界面点击设置弹出设置页面。

修改密码
首先是修改密码界面的布局代码
新建一个布局文件,名为activity_modify_psw

直接上代码。
activity_modify_psw.xml

<?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:background="@drawable/register_bg"    android:orientation="vertical">    <include layout="@layout/main_title_bar"/>    <EditText        android:id="@+id/et_original_psw"        android:layout_gravity="center_horizontal"        android:background="@drawable/register_user_name_bg"        android:layout_marginTop="35dp"        android:layout_marginLeft="35dp"        android:layout_marginRight="35dp"        android:drawableLeft="@drawable/psw_icon"        android:drawablePadding="10dp"        android:gravity="center_vertical"        android:hint="请输入原始密码"        android:inputType="textPassword"        android:paddingLeft="8dp"        android:textColor="#000000"        android:textColorHint="#a3a3a3"        android:textSize="14sp"        android:singleLine="true"        android:layout_width="match_parent"        android:layout_height="48dp"        />    <EditText        android:id="@+id/et_new_psw"        android:layout_gravity="center_horizontal"        android:background="@drawable/register_user_name_bg"        android:layout_marginLeft="35dp"        android:layout_marginRight="35dp"        android:drawableLeft="@drawable/psw_icon"        android:drawablePadding="10dp"        android:gravity="center_vertical"        android:hint="请输入新密码"        android:inputType="textPassword"        android:paddingLeft="8dp"        android:textColor="#000000"        android:textColorHint="#a3a3a3"        android:textSize="14sp"        android:layout_width="match_parent"        android:layout_height="48dp"        />    <EditText        android:id="@+id/et_new_psw_again"        android:layout_gravity="center_horizontal"        android:background="@drawable/register_user_name_bg"        android:layout_marginLeft="35dp"        android:layout_marginRight="35dp"        android:drawableLeft="@drawable/psw_icon"        android:drawablePadding="10dp"        android:gravity="center_vertical"        android:hint="请再次输入新密码"        android:inputType="textPassword"        android:paddingLeft="8dp"        android:singleLine="true"        android:textColor="#000000"        android:textColorHint="#a3a3a3"        android:textSize="14sp"        android:layout_width="match_parent"        android:layout_height="48dp"        />    <Button        android:id="@+id/btn_save"        android:layout_gravity="center_horizontal"        android:textSize="18sp"        android:textColor="@android:color/white"        android:layout_width="match_parent"        android:layout_height="40dp"        android:layout_marginTop="15dp"        android:layout_marginLeft="35dp"        android:layout_marginRight="35dp"        android:background="@drawable/register_selector"        android:text="保 存"/></LinearLayout>

生成activity文件,ModifyPswActivity.java
注意:在submit方法中,密码修改成功之后除了把当前页面关了,还要把设置界面也关了,所以用到instance

package cn.edu.gdmec.android.boxuegu.activity;import android.app.Activity;import android.content.Intent;import android.content.SharedPreferences;import android.os.Bundle;import android.text.TextUtils;import android.util.Log;import android.view.View;import android.widget.Button;import android.widget.EditText;import android.widget.RelativeLayout;import android.widget.TextView;import android.widget.Toast;import cn.edu.gdmec.android.boxuegu.R;import cn.edu.gdmec.android.boxuegu.utils.AnalysisUtils;import cn.edu.gdmec.android.boxuegu.utils.MD5Utils;public class ModifyPswActivity extends Activity implements View.OnClickListener {    private TextView tv_back;    private TextView tv_main_title;    private TextView tv_save;    private RelativeLayout title_bar;    private EditText et_original_psw;    private EditText et_new_psw;    private EditText et_new_psw_again;    private Button btn_save;    private String userName;    @Override    protected void onCreate(Bundle savedInstanceState) {        super.onCreate(savedInstanceState);        setContentView(R.layout.activity_modify_psw);        initView();        userName = AnalysisUtils.readLoginUserName(this);    }    private void initView() {        tv_back=findViewById(R.id.tv_back);        tv_main_title=findViewById(R.id.tv_main_title);        tv_save=findViewById(R.id.tv_save);        title_bar=findViewById(R.id.title_bar);        et_original_psw=findViewById(R.id.et_original_psw);        et_new_psw=findViewById(R.id.et_new_psw);        et_new_psw_again=findViewById(R.id.et_new_psw_again);        btn_save=findViewById(R.id.btn_save);        tv_main_title.setText("修改密码");        btn_save.setOnClickListener(this);        tv_back.setOnClickListener(this);    }    @Override    public void onClick(View view) {        switch (view.getId()) {            case R.id.btn_save:                submit();                break;            case R.id.tv_back:                finish();                break;        }    }    private void submit() {        String psw=et_original_psw.getText().toString().trim();        String newPsw=et_new_psw.getText().toString().trim();        String again=et_new_psw_again.getText().toString().trim();        if (TextUtils.isEmpty(psw)){            Toast.makeText(this,"请输入原始密码",Toast.LENGTH_SHORT).show();            return;        }else if (!MD5Utils.md5(psw).equals(readPsw())){            Log.i("MD5Utils.md5(psw)",""+MD5Utils.md5(psw));            Log.i("readPsw",""+readPsw());            Toast.makeText(this,"输入的密码与原始密码不一致",Toast.LENGTH_SHORT).show();            return;        }else if (MD5Utils.md5(newPsw).equals(readPsw())){            Toast.makeText(this,"输入的新密码与原始密码不能一致",Toast.LENGTH_SHORT).show();            return;        }else if (TextUtils.isEmpty(psw)){            Toast.makeText(this,"请输入密码",Toast.LENGTH_SHORT).show();            return;        }else if (TextUtils.isEmpty(again)){            Toast.makeText(this,"请再次输入新密码",Toast.LENGTH_SHORT).show();        }else if (!newPsw.equals(again)){            Toast.makeText(this,"再次输入的新密码不一致",Toast.LENGTH_SHORT).show();            return;        }else {            Toast.makeText(this,"新密码设置成功", Toast.LENGTH_SHORT).show();            modifyPsw(newPsw);//            Intent intent=new Intent(ModifyPswActivity.this,LoginActivity.class);            startActivity(intent);            //关闭设置页面            //在submit方法中,密码修改成功之后除了把当前页面关了,还要把设置界面也关了,所以用到instance            SettingActivity.instance.finish();            //关闭修改密码页面            ModifyPswActivity.this.finish();        }    }    private void modifyPsw(String newPsw) {        String md5psw= MD5Utils.md5(newPsw);        SharedPreferences sharedPreferences=getSharedPreferences("loginInfo",MODE_PRIVATE);        SharedPreferences.Editor editor = sharedPreferences.edit();        editor.putString(userName,md5psw);        editor.commit();    }    private String readPsw() {        SharedPreferences sharedPreferences=getSharedPreferences("loginInfo",MODE_PRIVATE);        String spPsw=sharedPreferences.getString(userName,"");        Log.i("username",userName);        Log.i("spPsw",spPsw);        return spPsw;    }}

注意:在submit方法中,密码修改成功之后除了把当前页面关了,还要把设置界面也关了,所以用到instance

SettingActivity.java,给它创个instance

SettingActivity.java

public class SettingActivity extends Activity implements View.OnClickListener{    private TextView tv_back;    private TextView tv_main_title;    private TextView tv_save;    private RelativeLayout title_bar;    private RelativeLayout rl_modify_psw;    private RelativeLayout rl_security_setting;    private RelativeLayout rl_exit_login;    public static SettingActivity instance=null;    @Override    protected void onCreate(Bundle savedInstanceState) {        super.onCreate(savedInstanceState);        setContentView(R.layout.activity_setting);        instance=this;        initView();    }

在onclick()中写上跳转方法。

SettingActivity.java

    @Override    public void onClick(View v) {        switch (v.getId()){            case R.id.tv_back:                SettingActivity.this.finish();                break;            case R.id.rl_modify_psw:                //修改密码界面                Intent intent=new Intent(SettingActivity.this,ModifyPswActivity.class);                startActivity(intent);                break;            case R.id.rl_security_setting:                //设置密保界面                break;            case R.id.rl_exit_login:                //退出登录,即清除登录状态                Toast.makeText(this,"退出登录成功",Toast.LENGTH_SHORT).show();                AnalysisUtils.cleanLoginStatus(this);                Intent data=new Intent();                data.putExtra("isLogin",false);                setResult(RESULT_OK,data);                finish();                break;        }    }

最后到AndroidManifest.xml声明下activity,运行程序,可看到效果

设置密保和找回密码
设置密保和找回密码页面需要用到的图片资源为
find_psw_icon.png

新建布局文件,名为activity_find_psw。

布局文件的代码:
activity_find_psw.xml

<?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:background="@drawable/login_bg"    android:orientation="vertical">    <!--找回密码需要设置标题栏-->    <include layout="@layout/main_title_bar" />    <TextView        android:id="@+id/tv_user_name"        android:layout_width="match_parent"        android:layout_height="wrap_content"        android:layout_marginLeft="35dp"        android:layout_marginRight="35dp"        android:layout_marginTop="35dp"        android:text="您的用户名是?"        android:textColor="@android:color/white"        android:textSize="18sp"        android:visibility="gone" />    <EditText        android:id="@+id/et_user_name"        android:layout_width="match_parent"        android:layout_height="wrap_content"        android:layout_marginLeft="35dp"        android:layout_marginRight="35dp"        android:layout_marginTop="10dp"        android:background="@drawable/find_psw_icon"        android:hint="请输入您的用户名"        android:inputType="text"        android:paddingLeft="8dp"        android:textColor="#000000"        android:textColorHint="#A3A3A3"        android:visibility="gone" />    <TextView        android:layout_width="match_parent"        android:layout_height="wrap_content"        android:layout_marginLeft="35dp"        android:layout_marginRight="35dp"        android:layout_marginTop="15dp"        android:text="您的姓名是?"        android:textColor="@android:color/white"        android:textSize="18sp"/>    <EditText        android:id="@+id/et_validate_name"        android:layout_width="match_parent"        android:layout_height="48dp"        android:layout_marginLeft="35dp"        android:layout_marginRight="35dp"        android:layout_marginTop="10dp"        android:background="@drawable/find_psw_icon"        android:hint="请输入要验证的姓名"        android:inputType="text"        android:paddingLeft="8dp"        android:textColor="#000000"        android:textColorHint="#A3A3A3" />    <TextView        android:id="@+id/tv_reset_psw"        android:layout_width="match_parent"        android:layout_height="wrap_content"        android:layout_marginLeft="35dp"        android:layout_marginRight="35dp"        android:layout_marginTop="15dp"        android:text="请输入新密码"        android:textColor="@android:color/white"        android:textSize="18sp"        android:visibility="gone"/>    <Button        android:id="@+id/btn_validate"        android:layout_width="match_parent"        android:layout_height="40dp"        android:layout_gravity="center_vertical"        android:layout_marginLeft="35dp"        android:layout_marginRight="35dp"        android:layout_marginTop="15dp"        android:background="@drawable/register_selector"        android:text="验 证"        android:textColor="@android:color/white"        android:textSize="18sp" /></LinearLayout>

生成Activity文件,FindPswActivity.java

FindPswActivity.java

package cn.edu.gdmec.android.boxuegu.activity;import android.app.Activity;import android.content.SharedPreferences;import android.os.Bundle;import android.text.TextUtils;import android.view.View;import android.widget.Button;import android.widget.EditText;import android.widget.RelativeLayout;import android.widget.TextView;import android.widget.Toast;import cn.edu.gdmec.android.boxuegu.R;import cn.edu.gdmec.android.boxuegu.utils.AnalysisUtils;import cn.edu.gdmec.android.boxuegu.utils.MD5Utils;public class FindPswActivity extends Activity implements View.OnClickListener {    private TextView tv_back;    private TextView tv_main_title;    private RelativeLayout title_bar;    private TextView tv_user_name;    private EditText et_user_name;    private EditText et_validate_name;    private TextView tv_reset_psw;    private Button btn_validate;    private String from;    @Override    protected void onCreate(Bundle savedInstanceState) {        super.onCreate(savedInstanceState);        setContentView(R.layout.activity_find_psw);        from=getIntent().getStringExtra("from");        initView();    }    private void initView() {        tv_back=findViewById(R.id.tv_back);        tv_main_title=findViewById(R.id.tv_main_title);        title_bar=findViewById(R.id.title_bar);        tv_user_name=findViewById(R.id.tv_user_name);        et_user_name=findViewById(R.id.et_user_name);        et_validate_name=findViewById(R.id.et_validate_name);        tv_reset_psw=findViewById(R.id.tv_reset_psw);        btn_validate=findViewById(R.id.btn_validate);        if ("security".equals(from)){            tv_main_title.setText("设置密保");        }else{            tv_main_title.setText("找回密码");            tv_user_name.setVisibility(View.VISIBLE);            et_user_name.setVisibility(View.VISIBLE);        }        tv_back.setOnClickListener(new View.OnClickListener() {            @Override            public void onClick(View v) {                FindPswActivity.this.finish();            }        });        btn_validate.setOnClickListener(this);    }    @Override    public void onClick(View view) {        switch (view.getId()) {            case R.id.btn_validate:                submit();                break;        }    }    private void submit() {        // validate        String validateName = et_validate_name.getText().toString().trim();        if ("security".equals(from)) {  //设置密保            if (TextUtils.isEmpty(validateName)) {                Toast.makeText(this, "请输入要验证的姓名", Toast.LENGTH_SHORT).show();                return;            } else {                Toast.makeText(this, "密保设置成功", Toast.LENGTH_SHORT).show();                //保存到                saveSecurity(validateName);                FindPswActivity.this.finish();                return;            }        }else {            final String name=et_user_name.getText().toString().trim();            String sp_security=readSecurity(name);            if (TextUtils.isEmpty(name)){                Toast.makeText(this,"请输入您的用户名",Toast.LENGTH_SHORT).show();                return;            }else if (!isExistUserName(name)){                Toast.makeText(this,"您输入的用户名不存在",Toast.LENGTH_SHORT).show();                return;            }else if (TextUtils.isEmpty(validateName)){                Toast.makeText(this,"请输入要验证的姓名",Toast.LENGTH_SHORT).show();                return;            }else if (!validateName.equals(sp_security)){                Toast.makeText(this,"输入的密保不正确",Toast.LENGTH_SHORT).show();                return;            }else {                tv_reset_psw.setVisibility(View.VISIBLE);                tv_reset_psw.setText("初始密码:123456");                savePsw(name);            }        }    }    /**     * 保存初始化密码     **/    private void savePsw(String name) {        String md5Psw= MD5Utils.md5("123456");        SharedPreferences sharedPreferences = getSharedPreferences("loginInfo",MODE_PRIVATE);        SharedPreferences.Editor editor = sharedPreferences.edit();        editor.putString(name,md5Psw);        editor.commit();    }    private boolean isExistUserName(String name){        boolean hasUserName=false;        SharedPreferences sharedPreferences=getSharedPreferences("loginInfo",MODE_PRIVATE);        String spPsw=sharedPreferences.getString(name,"");        if (!TextUtils.isEmpty(spPsw)){            hasUserName=true;        }        return hasUserName;    }    /**     * 读取密保     **/    private String readSecurity(String name){        SharedPreferences sharedPreferences=getSharedPreferences("loginInfo",MODE_PRIVATE);        String security=sharedPreferences.getString(name+"_security","");        return security;    }    /**     * 保存密保名字     **/    private void saveSecurity(String validateName) {        SharedPreferences sharedPreferences=getSharedPreferences("loginInfo",MODE_PRIVATE);        SharedPreferences.Editor editor=sharedPreferences.edit();        editor.putString(AnalysisUtils.readLoginUserName(this)+"_security",validateName);        editor.commit();    }}

把找回密码和设置密保都放在一个Activity里了,所以我们要到登录界面和设置界面添加跳转方法。
到LoginActivity的init()方法里找到tv_find_psw.setOnClickListener。

LoginActivity.java

        //找回密码控件的点击事件        tv_find_psw.setOnClickListener(new View.OnClickListener() {            @Override            public void onClick(View v) {                //跳转到找回密码界面(此页面暂未创建)                Intent intent=new Intent(LoginActivity.this,FindPswActivity.class);                startActivity(intent);            }        });

SettingActivity的onClick()方法里添加跳转代码

    @Override    public void onClick(View v) {        switch (v.getId()){            case R.id.tv_back:                SettingActivity.this.finish();                break;            case R.id.rl_modify_psw:                //修改密码界面                Intent intent=new Intent(SettingActivity.this,ModifyPswActivity.class);                startActivity(intent);                break;            case R.id.rl_security_setting:                //设置密保界面                Intent intent1=new Intent(SettingActivity.this,FindPswActivity.class);                intent1.putExtra("from","security");                startActivity(intent1);                break;            case R.id.rl_exit_login:                //退出登录,即清除登录状态                Toast.makeText(this,"退出登录成功",Toast.LENGTH_SHORT).show();                AnalysisUtils.cleanLoginStatus(this);                Intent data=new Intent();                data.putExtra("isLogin",false);                setResult(RESULT_OK,data);                finish();                break;        }    }

最后到AndroidManifest.xml声明下activity

AndroidManifest.xml

<?xml version="1.0" encoding="utf-8"?><manifest xmlns:android="http://schemas.android.com/apk/res/android"    package="cn.edu.gdmec.android.boxuegu">    <!--原为android:theme="@style/AppTheme"-->    <!--去除ActionBar标题栏-->    <!--添加应用图标,app_icon-->    <application        android:allowBackup="true"        android:icon="@drawable/app_icon"        android:label="@string/app_name"        android:roundIcon="@mipmap/ic_launcher_round"        android:supportsRtl="true"        android:theme="@style/Theme.AppCompat.NoActionBar">        <activity android:name=".activity.SplashActivity">            <intent-filter>                <action android:name="android.intent.action.MAIN" />                <category android:name="android.intent.category.LAUNCHER" />            </intent-filter>        </activity>        <!--添加实现类-->        <activity android:name=".activity.MainActivity"></activity>        <activity android:name=".activity.LoginActivity"></activity>        <activity android:name=".activity.RegisterActivity"></activity>        <activity android:name=".activity.SettingActivity"></activity>        <activity android:name=".activity.ModifyPswActivity"></activity>        <activity android:name=".activity.FindPswActivity"></activity>    </application></manifest>

任务实施
修复fragment的小BUG
在未登录状态下,点击“点击登陆”,登陆完成后,应该显示“我”的界面,并且正常显示用户名。

在登陆状态下,点击“设置”->点击退出登录,应该继续显示“我”的界面,并且正常显示用户名。

修改密保设置页面
密保设置页面的按钮显示的是“验证”,这里应该是“设置”比较合理。
把按钮上的文字改成“设置”,要求修改密码界面按钮依然是“验证”。

优化找回密码
登陆界面的找回密码功能用的是初始化密码,要求改成设置新密码。
注意:显示设置新密码框时,按钮的文字也要变化哦!

更改后的效果:

教育系统APP(四)插图1
file

总结
这是走好Android的四步!

❤️ 不要忘记留下你学习的脚印 [点赞 + 收藏 + 评论]

作者Info:

【作者】:Jeskson
【原创公众号】:达达前端小酒馆。
【福利】:公众号回复 “资料” 送自学资料大礼包(进群分享,想要啥就说哈,看我有没有)!
【转载说明】:转载请说明出处,谢谢合作!~

大前端开发,定位前端开发技术栈博客,PHP后台知识点,web全栈技术领域,数据结构与算法、网络原理等通俗易懂的呈现给小伙伴。谢谢支持,承蒙厚爱!!!


若本号内容有做得不到位的地方(比如:涉及版权或其他问题),请及时联系我们进行整改即可,会在第一时间进行处理。


请点赞!因为你们的赞同/鼓励是我写作的最大动力!

欢迎关注达达的CSDN!

这是一个有质量,有态度的博客

教育系统APP(四)插图2
前端技术栈

文章转载于:https://www.jianshu.com/p/362fa1f8ef42

原著是一个有趣的人,若有侵权,请通知删除

未经允许不得转载:起风网 » 教育系统APP(四)
分享到: 生成海报

评论 抢沙发

评论前必须登录!

立即登录