版權聲明:本文爲HaiyuKing原創文章,轉載請註明出處!android
記錄輸入框顯示、隱藏密碼的簡單佈局以及實現方式。windows
方式一app
/**方式一:*/
private void showOrHiddenPwd(){
if(! showPwd){ showPwd = true; img_pwdshow.setImageResource(R.drawable.pwd_show); //顯示密碼 edt_password.setTransformationMethod(HideReturnsTransformationMethod.getInstance()); }else{ showPwd = false; img_pwdshow.setImageResource(R.drawable.pwd_hidden); //隱藏密碼 edt_password.setTransformationMethod(PasswordTransformationMethod.getInstance()); } }
方式二ide
/**方式二:*/
private void showOrHiddenPwdWithInputType(){
if(! showPwd){ showPwd = true; img_pwdshow.setImageResource(R.drawable.pwd_show); //顯示密碼 edt_password.setInputType(InputType.TYPE_TEXT_VARIATION_VISIBLE_PASSWORD); }else{ showPwd = false; img_pwdshow.setImageResource(R.drawable.pwd_hidden); //隱藏密碼 edt_password.setInputType(InputType.TYPE_CLASS_TEXT | InputType.TYPE_TEXT_VARIATION_PASSWORD); } }
注意事項:佈局
一、 導入類文件後須要change包名以及從新import R文件路徑spa
二、 Values目錄下的文件(strings.xml、dimens.xml、colors.xml等),若是項目中存在,則複製裏面的內容,不要整個覆蓋.net
<?xml version="1.0" encoding="utf-8"?> <!-- 輸入框背景圖 --> <selector xmlns:android="http://schemas.android.com/apk/res/android" > <!--選中時效果--> <!-- <item android:state_focused="true" android:drawable="@drawable/input_box_focused" /> --> <!--disable效果 windows焦點在前時 注意寫法--> <!-- <item android:state_window_focused="true" android:state_enabled="false" android:drawable="@drawable/input_box_focused" /> --> <!--默認時效果--> <!-- <item android:drawable="@drawable/input_box_unfocused" /> --> <!-- 選中時效果 --> <item android:state_focused="true"> <shape android:shape="rectangle"> <!-- 圓角 --> <corners android:radius="3dp" /> <!-- 描邊 --> <stroke android:width="1dp" android:color="#1296db" /> <!-- 內邊距 --> <padding android:bottom="5dp" android:left="5dp" android:right="5dp" android:top="5dp" /> <!-- 填充 --> <solid android:color="@android:color/transparent" /> </shape> </item> <!-- disable效果 windows焦點在前時 注意寫法 --> <item android:state_enabled="false" android:state_window_focused="true"> <shape android:shape="rectangle"> <!-- 圓角 --> <corners android:radius="3dp" /> <!-- 描邊 --> <stroke android:width="1dp" android:color="#1296db" /> <!-- 內邊距 --> <padding android:bottom="5dp" android:left="5dp" android:right="5dp" android:top="5dp" /> <!-- 填充 --> <solid android:color="@android:color/transparent" /> </shape> </item> <!-- 默認時效果 --> <item> <shape android:shape="rectangle"> <!-- 圓角 --> <corners android:radius="3dp" /> <!-- 描邊 --> <stroke android:width="1dp" android:color="#9f9f9f" /> <!-- 內邊距 --> <padding android:bottom="5dp" android:left="5dp" android:right="5dp" android:top="5dp" /> <!-- 填充 --> <solid android:color="@android:color/transparent" /> </shape> </item> </selector>
<?xml version="1.0" encoding="utf-8"?> <!-- Android中EditText顯示明文與密文的兩種方式 --> <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.why.project.androidcnblogsdemo.activity.MainActivity"> <!-- 當之有一個EditText或者AutoCompleteTextView的時候,進入畫面時是默認獲得焦點的。 要想去除焦點,能夠在auto以前加一個0像素的layout,並設置他先獲得焦點。 --> <LinearLayout android:layout_width="0px" android:layout_height="0px" android:focusable="true" android:focusableInTouchMode="true"/> <!-- 輸入密碼區域 --> <LinearLayout android:layout_width="match_parent" android:layout_height="50dp" android:orientation="horizontal" android:background="@drawable/comm_input_selector" android:focusable="true" android:clickable="true" android:addStatesFromChildren="true" android:layout_margin="5dp"> <EditText android:id="@+id/edt_password" android:layout_width="0.0dp" android:layout_height="match_parent" android:layout_weight="1" android:background="@null" android:hint="請輸入密碼" android:textSize="18sp" android:imeOptions="actionGo" android:inputType="textPassword" android:text="" android:textColor="#000000" android:textColorHint="#8c8c8c" android:drawableLeft="@drawable/pwd_img" android:drawablePadding="10dp" /> <!-- 顯示隱藏密碼圖標 --> <ImageView android:id="@+id/img_pwdshow" android:layout_width="wrap_content" android:layout_height="match_parent" android:src="@drawable/pwd_hidden" android:scaleType="fitCenter" android:contentDescription="控制密碼明文密文顯示" android:paddingLeft="10dp" android:paddingRight="10dp" android:focusable="true" android:clickable="true"/> </LinearLayout> </RelativeLayout>
package com.why.project.androidcnblogsdemo.activity; import android.os.Bundle; import android.support.v7.app.AppCompatActivity; import android.text.InputType; import android.text.method.HideReturnsTransformationMethod; import android.text.method.PasswordTransformationMethod; import android.view.View; import android.widget.EditText; import android.widget.ImageView; import com.why.project.androidcnblogsdemo.R; /** * Android中EditText顯示明文與密文的兩種方式*/ public class MainActivity extends AppCompatActivity { private EditText edt_password; private ImageView img_pwdshow; private boolean showPwd = false;//默認不顯示密碼 @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); initViews(); initEvents(); } private void initViews() { edt_password = (EditText) findViewById(R.id.edt_password); img_pwdshow = (ImageView) findViewById(R.id.img_pwdshow); } private void initEvents() { img_pwdshow.setOnClickListener(new View.OnClickListener() { @Override public void onClick(View v) { showOrHiddenPwdWithInputType(); } }); } /**方式一:*/ private void showOrHiddenPwd(){ if(! showPwd){ showPwd = true; img_pwdshow.setImageResource(R.drawable.pwd_show); //顯示密碼 edt_password.setTransformationMethod(HideReturnsTransformationMethod.getInstance()); }else{ showPwd = false; img_pwdshow.setImageResource(R.drawable.pwd_hidden); //隱藏密碼 edt_password.setTransformationMethod(PasswordTransformationMethod.getInstance()); } } /**方式二:*/ private void showOrHiddenPwdWithInputType(){ if(! showPwd){ showPwd = true; img_pwdshow.setImageResource(R.drawable.pwd_show); //顯示密碼 edt_password.setInputType(InputType.TYPE_TEXT_VARIATION_VISIBLE_PASSWORD); }else{ showPwd = false; img_pwdshow.setImageResource(R.drawable.pwd_hidden); //隱藏密碼 edt_password.setInputType(InputType.TYPE_CLASS_TEXT | InputType.TYPE_TEXT_VARIATION_PASSWORD); } } }
無3d
Android中EditText顯示明文與密碼的兩種方式orm
暫時空缺