package com.qyk.douban.widget; import android.content.Context;
import android.text.Editable;
import android.text.InputType;
import android.text.Selection;
import android.text.TextWatcher;
import android.util.AttributeSet;
import android.view.View;
import android.view.View.OnClickListener;
import android.view.ViewGroup;
import android.widget.EditText;
import android.widget.TextView; public class EditTextPassWordVisiable extends ViewGroup implements OnClickListener { private TextView clearImage;
private EditText editText;
private boolean pswVisiable = false;
private int clearImageRightPading = 20; private int drawableVisiable,drawableUnVisiable; private TextWatcher textWatcher = new TextWatcher() { @Override
public void onTextChanged(CharSequence s, int start, int before, int count) { } @Override
public void beforeTextChanged(CharSequence s, int start, int count, int after) { } @Override
public void afterTextChanged(Editable s) {
// if (s.length() == 0) {
// clearImage.setVisibility(View.GONE);
// } else {
// clearImage.setVisibility(View.VISIBLE);
// }
}
}; public EditTextPassWordVisiable(Context context) {
super(context);
initViews();
} public EditTextPassWordVisiable(Context context, AttributeSet attrs) {
super(context, attrs);
initViews();
} public EditTextPassWordVisiable(Context context, AttributeSet attrs, int defStyle) {
super(context, attrs, defStyle);
initViews();
} private void initViews() {
final Context mContext = getContext();
clearImage = new TextView(mContext);
clearImage.setLayoutParams(new ViewGroup.LayoutParams(LayoutParams.WRAP_CONTENT, LayoutParams.WRAP_CONTENT));
clearImage.setOnClickListener(this);
editText = new EditText(mContext);
editText.setLayoutParams(new ViewGroup.LayoutParams(LayoutParams.MATCH_PARENT, LayoutParams.WRAP_CONTENT));
editText.addTextChangedListener(textWatcher);
editText.setSingleLine(true);
addView(editText);
addView(clearImage);
requestLayout();
} /**
* 设置 清除图片 的资源
*
* @param drawableId
*/
public void setClearImageDrawableId(int drawableId) {
clearImage.setBackgroundResource(drawableId);
} /**
* 设置EditText的padding(如果调用了{@link #setEditTextBackGround(int)}
* 方法,其背景图片是.9图的话,必须要调用此方法)
*
* @param paddingLeft 左边的padding
* @param paddinTop 上边padding
* @param paddingRight 右边padding(这个padding是指文章到 清除图片的 padding)
* @param paddingBottom 下边padding
*/
public void setEditTextPadding(int paddingLeft, int paddinTop, int paddingRight, int paddingBottom) {
paddingRight += clearImageRightPading + clearImage.getBackground().getIntrinsicWidth();
editText.setPadding(paddingLeft, paddinTop, paddingRight, paddingBottom);
} /**
* 设置删除图片距离右边的距离
*
* @param clearImageRightPading
*/
public void setClearImageRightPadding(int clearImageRightPading) {
this.clearImageRightPading = clearImageRightPading;
requestLayout();
} /**
* 设置EditText的背景</br>Note</br>(1)调用了该方法之后,如果背景图是.9图的话,必须调用
* {@link #setEditTextPadding(int, int, int, int)}方法 </br>(2)此方法必须是调用了
* {@link #setClearImageDrawableId(int)}之后才能调用
*
* @param resid
*/
public void setEditTextBackGround(int resid) {
editText.setBackgroundResource(resid);
} public void setTextColor(int color) {
editText.setTextColor(color);
} public void setTextSize(int size) {
editText.setTextSize(size);
} @Override
protected void onMeasure(int widthMeasureSpec, int heightMeasureSpec) {
super.onMeasure(widthMeasureSpec, heightMeasureSpec);
int width = MeasureSpec.getSize(widthMeasureSpec);
// int height = MeasureSpec.getSize(heightMeasureSpec);
int childCount = getChildCount();
for (int i = 0; i < childCount; i++) {
if (i == 0) {
getChildAt(i).measure(MeasureSpec.makeMeasureSpec(getWidth(), MeasureSpec.EXACTLY),
getDefaultSize(getSuggestedMinimumHeight(), heightMeasureSpec));
} else {
TextView secondView = (TextView) getChildAt(i);
secondView.measure(MeasureSpec.makeMeasureSpec(secondView.getBackground().getIntrinsicWidth(), MeasureSpec.UNSPECIFIED),
MeasureSpec.makeMeasureSpec(secondView.getBackground().getIntrinsicHeight(), MeasureSpec.UNSPECIFIED));
}
}
setMeasuredDimension(width, getChildAt(0).getMeasuredHeight());
} @Override
protected void onLayout(boolean changed, int l, int t, int r, int b) {
final EditText firstView = editText;
final View secondView = clearImage;
final int editTextWith = firstView.getMeasuredWidth();
final int imageViewWidth = secondView.getMeasuredWidth();
firstView.layout(0, 0, editTextWith, firstView.getMeasuredHeight());
final int top = (firstView.getMeasuredHeight() - secondView.getMeasuredHeight()) >> 1;
secondView.layout(editTextWith - imageViewWidth - clearImageRightPading, top, editTextWith - clearImageRightPading, top
+ secondView.getMeasuredHeight());
} @Override
public void onClick(View v) {
pswVisiable = !pswVisiable;
if (pswVisiable) {
setClearImageDrawableId(getDrawableVisiable());
editText.setInputType(InputType.TYPE_TEXT_VARIATION_VISIBLE_PASSWORD);
Editable etable = editText.getText();
Selection.setSelection(etable, etable.length());
} else {
setClearImageDrawableId(getDrawableUnVisiable());
editText.setInputType(InputType.TYPE_CLASS_TEXT | InputType.TYPE_TEXT_VARIATION_PASSWORD);
//下面两行代码实现: 输入框光标一直在输入文本后面
Editable etable = editText.getText();
Selection.setSelection(etable, etable.length());
} } /**
* 获得密码可见图标
* @return
*/
public int getDrawableVisiable() {
return drawableVisiable;
} /**
* 获得密码不可见图标
* @return
*/
public int getDrawableUnVisiable() {
return drawableUnVisiable;
} /**
* 设置密码可见的图标
* @param drawableVisiable
*/
public void setDrawableVisiable(int drawableVisiable) {
this.drawableVisiable = drawableVisiable;
} /**
* 设置密码不可见的图标
* @param drawableUnVisiable
*/
public void setDrawableUnVisiable(int drawableUnVisiable) {
this.drawableUnVisiable = drawableUnVisiable;
}
}
                clearEditText.setDrawableVisiable(R.drawable.eye_open);//必须
clearEditText.setDrawableUnVisiable(R.drawable.eye_closed);//必须
clearEditText.setClearImageDrawableId(clearEditText.getDrawableUnVisiable());//设置默认情况的图标 // clearEditText.setEditTextBackGround(R.drawable.bg_tab_search_edit);
clearEditText.setEditTextPadding(30, 20, 20, 20);
clearEditText.setClearImageRightPadding(20);
clearEditText.setTextColor(R.color.colorPrimaryDark);

  

自定义 密码是否可见 的EditView 右侧带个小眼睛的更多相关文章

  1. 基于jQuery右侧带缩略图导航的焦点图

    今天我们要来分享一款右侧带缩略图导航的jQuery焦点图插件,这款jQuery焦点图插件的特点是右侧有一列缩略图导航列表,并且可以定义任意数量的图片,你可以拖动列表来查看所有的图片,点击缩略图后,即可 ...

  2. 安装mysql的步骤并利用mysql原始密码修改自定义密码

    1.给刚下载好的mysql软件tar包,进行解包 命令:tar -xf mysql-5.7.26-1.el7.x86_64.rpm-bundle.tar 然后利用yum装包 命令:yum -y ins ...

  3. 【Azure Redis 缓存】由Azure Redis是否可以自定义密码而引申出Azure PaaS的Redis服务是否可以和自建的Redis进行主从配置呢?

    问题描述 在自建的Redis服务中,可以通过 config set requirepass <Password> 设置Redis的登录密码,然后使用auth 命令输入密码.操作命令如下: ...

  4. Chrome自带恐龙小游戏的源码研究(一)

    目录 Chrome自带恐龙小游戏的源码研究(一)——绘制地面 Chrome自带恐龙小游戏的源码研究(二)——绘制云朵 Chrome自带恐龙小游戏的源码研究(三)——昼夜交替 Chrome自带恐龙小游戏 ...

  5. IE9+浏览器input文本框/密码框后面的小叉子/小眼睛清除

    为了方便我们的触控操作,IE高等浏览器针对input及input type="password"分别提供了快速清除钮(X图标)以及密码文字显示钮(小眼睛图标)的功能. 由于这经常跟 ...

  6. ie9以上浏览器input文本框/密码框后面的小叉子/小眼睛问题

    找了很久不知什么属性控制的这个东西,经过群友的指点重要找到.

  7. 去除html页面中按钮在ios中的默认样式,去除select自带的小三角图标

    btn{-webkit-appearance: none;} -webkit-appearance: none也能去掉select下拉列表后面自带的小三角

  8. Chrome自带恐龙小游戏的源码研究(七)

    在上一篇<Chrome自带恐龙小游戏的源码研究(六)>中研究了恐龙的跳跃过程,这一篇研究恐龙与障碍物之间的碰撞检测. 碰撞盒子 游戏中采用的是矩形(非旋转矩形)碰撞.这类碰撞优点是计算比较 ...

  9. Chrome自带恐龙小游戏的源码研究(完)

    在上一篇<Chrome自带恐龙小游戏的源码研究(七)>中研究了恐龙与障碍物的碰撞检测,这一篇主要研究组成游戏的其它要素. 游戏分数记录 如图所示,分数及最高分记录显示在游戏界面的右上角,每 ...

随机推荐

  1. eclipse编辑jsp快捷键保存时特别卡的解决方法

    今天eclipse用着用着的时候,每次编辑jsp页面快捷键保存的时候要等半天才保存好,特别的卡.搞的很蛋疼.上网搜了下有解决办法 Window -> Preference -> Gener ...

  2. eclipse字体推荐

    首先大家可以看看这里面推荐的最佳十款字体,http://www.iteye.com/news/11102-10-great-programming-font 但是经过测试发现,排名第一的字体在ecli ...

  3. 2016 ACM/ICPC Asia Regional Qingdao Online HDU5878

    链接:http://acm.hdu.edu.cn/showproblem.php?pid=5878 解法:先保存,再二分查询~具体http://blog.csdn.net/coder_xia/arti ...

  4. 2016年6月25日 星期六 --出埃及记 Exodus 14:22

    2016年6月25日 星期六 --出埃及记 Exodus 14:22 and the Israelites went through the sea on dry ground, with a wal ...

  5. mysql计划任务

    这两天一直遇见mysql计划任务的案例,今天我就给大家分享一个真是的实例: 1.创建计划任务的语法: create event 任务名称 on schedule  at 时间周期 starts '年- ...

  6. Xcode插件管理以及Xcode7 升级

    一,Xcode插件管理工具 Alcatraz: mkdir -p ~/Library/Application\ Support/Developer/Shared/Xcode/Plug-ins; cur ...

  7. MySQL操作数据库和表的常用命令新手教程

    1.查看数据库 获取服务器上的数据库列表通常很有用.执行show databases;命令就可以搞定. mysql> show databases; 2.创建数据库 mysql> crea ...

  8. Linux下mysql备份 恢复

    转载自http://blog.chinaunix.net/uid-20577907-id-161611.html 比如我们要备份mysql中已经存在的名为linux的数据库,要用到命令mysqldum ...

  9. SqlSever基础 left函数 从左边开始截取字符串

    镇场诗:---大梦谁觉,水月中建博客.百千磨难,才知世事无常.---今持佛语,技术无量愿学.愿尽所学,铸一良心博客.------------------------------------------ ...

  10. SqlSever基础 Upper函数 返回字符串的大写形式

    镇场诗:---大梦谁觉,水月中建博客.百千磨难,才知世事无常.---今持佛语,技术无量愿学.愿尽所学,铸一良心博客.------------------------------------------ ...