EditText 显示明文和密码

1、效果图

 

2、布局文件

<?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: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="wifi.app.wei.com.myapplication.MainActivity">

    <RelativeLayout
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:padding="10dp"
        >

        <ImageView
            android:id="@+id/image"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:src="@mipmap/eye_close"
            android:layout_alignParentRight="true"
            android:layout_centerVertical="true"
            />

        <EditText
            android:id="@+id/pass_et"
            android:layout_toLeftOf="@id/image"
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:inputType="textPassword"
            />

    </RelativeLayout>

</RelativeLayout>

  

3、代码实现(方式一)

package wifi.app.wei.com.myapplication;

import android.os.Bundle;
import android.support.v7.app.AppCompatActivity;
import android.text.InputType;
import android.view.View;
import android.widget.EditText;
import android.widget.ImageView;

public class MainActivity extends AppCompatActivity {

    private ImageView imageView ;
    private EditText editText ;
    boolean eyeOpen = false ;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main );
        imageView = (ImageView) findViewById( R.id.image) ;
        editText = (EditText) findViewById( R.id.pass_et);

        imageView.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View view) {
                if ( eyeOpen ){
                    //密码 TYPE_CLASS_TEXT 和 TYPE_TEXT_VARIATION_PASSWORD 必须一起使用
                    editText.setInputType(InputType.TYPE_CLASS_TEXT | InputType.TYPE_TEXT_VARIATION_PASSWORD);
                    imageView.setImageResource( R.mipmap.eye_close );
                    eyeOpen = false ;
                }else {
                    //明文
                    editText.setInputType( InputType.TYPE_TEXT_VARIATION_VISIBLE_PASSWORD );
                    imageView.setImageResource( R.mipmap.eye_open );
                    eyeOpen = true ;
                }
            }
        });
    }
}

  

 4、代码实现(方式二)

package wifi.app.wei.com.myapplication;

import android.os.Bundle;
import android.support.v7.app.AppCompatActivity;
import android.text.method.HideReturnsTransformationMethod;
import android.text.method.PasswordTransformationMethod;
import android.view.View;
import android.widget.EditText;
import android.widget.ImageView;

public class MainActivity extends AppCompatActivity {

    private ImageView imageView ;
    private EditText editText ;
    boolean eyeOpen = false ;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main );
        imageView = (ImageView) findViewById( R.id.image) ;
        editText = (EditText) findViewById( R.id.pass_et);

        imageView.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View view) {
                if ( eyeOpen ){
                    //密码
                    editText.setTransformationMethod(PasswordTransformationMethod.getInstance());
                    imageView.setImageResource( R.mipmap.eye_close );
                    eyeOpen = false ;
                }else {
                    //明文
                    editText.setTransformationMethod(HideReturnsTransformationMethod.getInstance());
                    imageView.setImageResource( R.mipmap.eye_open );
                    eyeOpen = true ;
                }
            }
        });
    }
}

  

 

时间: 2024-10-31 08:28:18

EditText 显示明文和密码的相关文章

Android中EditText显示明文与密码的两种方式_Android

效果图如下所述: 布局 <?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:tools="http://schemas.android.com/tools" android:layout_width="match_pa

Android中EditText显示明文与密码的两种方式

效果图如下所述: 布局 <?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:tools="http://schemas.android.com/tools" android:layout_width="match_pa

服务器注册的环信账号,用代码登录时总是显示 “账号或密码错误”! 何解??

问题描述 begin login username:072b0b198a2c411d886cb9c20acff198--password:111111-- 解决方案 看下客户端和服务端是一个appkey吗?检查下注册填写的用户名密码和登录时使用一个吗解决方案二:appkey是相同的,我测试了一下一周前(服务器批量注册)显示账号或密码错误的账号,现在都能直接登录了,但是刚注册的账号还是不行,难道还有滞后问题吗??解决方案三:当前注册用户总数: 60816    刚看了一下我们后台一次注册了6万多账

我的php登录界面总是显示我账号密码错误。。。我找不出错误 恳求各位大神帮助

问题描述 我的php登录界面总是显示我账号密码错误...我找不出错误 恳求各位大神帮助 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <html xmlns="http://www.w3.org/1999/xhtml"> <

显示、隐藏密码_表单特效

<html> <head> <meta http-equiv="Content-Type" content="text/html; charset=gb2312"> <meta name="GENERATOR" content="Microsoft FrontPage 4.0"> <meta name="ProgId" content="Fro

win8系统明文显示加星密码的方法

  熟悉电脑的朋友都知道,一般在电脑上输入的密码都是用"*"代替,主要是为保密方便,但是如果是只有自己或值得信任的人使用电脑,就没有保密的必要性了,且有时候登陆时输错密码反而难以发现,给使用造成诸多不便,本文介绍在win8系统下怎么让密码变成明文显示. 在Win8系统中,遇到需要输入密码的对话框就会在密码框的右侧显示一只眼睛装的图标,如图所示: 用鼠标去点击密码输入框后方的眼睛,就可以让密码明文显示了,如下图所示: 以上就是Win8系统中怎么让密码明文显示的方法

Android 打勾显示输入的密码 --EditText与setTransformationMethod

http://www.cnblogs.com/xilifeng/archive/2012/08/18/2645189.html

我擦,csdn一个技术类网站竟然明文保存密码

问题描述 这是哪个2B设计的啊,靠 解决方案 解决方案二:我感觉非常的不靠谱啊解决方案三:赶紧改邮箱吧解决方案四:MySQL被注入了?这么牛b?没想到7-8年之后动网注入依然犀利啊..解决方案五:习惯就好解决方案六:该回复于2011-12-22 16:32:54被版主删除解决方案七:谁干的呀!牛人呀!解决方案八:该回复于2011-12-22 16:33:01被版主删除解决方案九:该回复于2011-12-22 16:33:09被版主删除解决方案十:剛開始是一般垃圾人開發的,後來註冊會員多了,改變的

linux桌面系统使用明文ssh密码登陆远程服务器

1. linux系统下登陆远程服务器最安全的方式还是用免密码登录 2. 原理 通过公钥加密,私钥解密去实现的. 用户机子存的是私钥,远程机子存的是对应的公钥. 远程机子通过公钥加密"一段文字"给用户机子. 用户机子通过私钥去解密,并得到"这段文字",然后以明文形式发送给远程机子. 远程机子验证接收到的文字信息是否和给出的文字信息一致,一致就确定用户可信,用户即为真实用户. 实现1 首先通过ssh登录远程机子,这里命名为DEV机子.(ssh yansong@dev,然