Я хочу настроить edittext, когда пользователь вводит символ, а затем edittext меняет его на изображение. Посмотрите, как изображение:
Примечание: ● изображение не является символом.
Я хочу настроить edittext, когда пользователь вводит символ, а затем edittext меняет его на изображение. Посмотрите, как изображение:
Примечание: ● изображение не является символом.
вам нужно расширить PasswordTransformationMethod
и использовать setTransformationMethod
метод EditText
.
edt.setTransformationMethod(new CustomPasswordTransformationMethod());
и вставьте этот CustomPasswordTransformationMethod
class CustomPasswordTransformationMethod extends PasswordTransformationMethod {
@Override
public CharSequence getTransformation(CharSequence source, View view) {
return new PasswordCharSequence(source);
}
private class PasswordCharSequence implements CharSequence {
private CharSequence source;
public PasswordCharSequence(CharSequence source) {
this.source = source;
}
public char charAt(int index) {
if(index>4) //your own condition, when you want to hide characters.
return 0x2022; // change this to bullets you want like '*' or '.'
return source.charAt(index);
}
public int length() {
return source.length();
}
public CharSequence subSequence(int start, int end) {
return source.subSequence(start, end);
}
}
}
Выше код будет писать символ, так как он не более 5 символов, после чего он будет печатать марки в EditText
.
Ссылка, взятая из this post
UPDATE
Наконец, вот ваш ответ:
Spannable.Factory spannableFactory;
int lastIndex = -1;
spannableFactory = Spannable.Factory
.getInstance();
1. добавьте addTextChangedListener
в EditText
.
mEditText.addTextChangedListener(watcher);
TextWatcher watcher = new TextWatcher() {
@Override
public void beforeTextChanged(CharSequence s, int start, int count, int after) {
}
@Override
public void onTextChanged(CharSequence s, int start, int before, int count) {
if (start>4) {
mEditText.removeTextChangedListener(watcher);
mEditText.setText(getIconText(context, s, start));
mEditText.addTextChangedListener(watcher);
mEditText.setSelection(s.length());
}
}
@Override
public void afterTextChanged(Editable s) {
}
};
Преобразуйте свой drawable в Spannable
public Spannable getIconText(Context context, CharSequence text, int index) {
Spannable spannable = spannableFactory.newSpannable(text);
if (index>lastIndex) {
spannable.setSpan(new ImageSpan(context, R.drawable.bullet_point),
index, index + 1,
Spannable.SPAN_EXCLUSIVE_EXCLUSIVE);
}
lastIndex=index;
return spannable;
}
Скажем, если вы хотите заменить символ b символом ●. Затем вы можете добавить TextWatcher для этого, который выглядит следующим образом:
myEditText.addTextChangedListener(new TextWatcher() {
@Override
public void beforeTextChanged(CharSequence s, int start, int count, int after) {
}
@Override
public void onTextChanged(CharSequence s, int start, int before, int count) {
StringBuilder myText = new StringBuilder(myEditText.getText().toString());
if (myText.toString().contains("b")){ //If this contains b
myText.setCharAt(myText.indexOf("b"),'●');
myEditText.setText(myText.toString()); //Sets the string to EditText
myEditText.setSelection(myText.length()); //Moves cursor to the last after replacing
}
}
@Override
public void afterTextChanged(Editable s) {
}
});
UPDATE
мы можем использовать setCompoundDrawablesWithIntrinsicBounds для размещения изображения, но не можем разместить его как символ в точном положении. мы можем определить только границы.
использовать свойство edittext inputtype в вашем xml
android:inputType="textPassword"
Попробуйте это в своем коде. doc
EditText text = (EditText) findViewById(R.id.edtTest);
text.setCompoundDrawablesWithIntrinsicBounds(null, null,
getResources().getDrawable(R.drawable.myDrawable), null);