EditText
Androidでテキストの長さを制限する最良の方法は何ですか?
xml経由でこれを行う方法はありますか?
入力フィルタを使用して、テキスト ビューの最大長を制限します。
TextView editEntryView = new TextView(...);
InputFilter[] filterArray = new InputFilter[1];
filterArray[0] = new InputFilter.LengthFilter(8);
editEntryView.setFilters(filterArray);
EditText editText = new EditText(this);
int maxLength = 3;
editText.setFilters(new InputFilter[] {new InputFilter.LengthFilter(maxLength)});
すでにカスタム入力フィルターを使用していて、最大長を制限したい人への注意:
コードで入力フィルターを割り当てると、。で設定されたものを含め、以前に設定されたすべての入力フィルターがクリアされandroid:maxLength
ます。これは、カスタム入力フィルターを使用して、パスワードフィールドで許可されていない一部の文字の使用を防止しようとしたときにわかりました。setFiltersでそのフィルターを設定した後、maxLengthは観察されなくなりました。解決策は、maxLengthとカスタムフィルターをプログラムで一緒に設定することでした。このようなもの:
myEditText.setFilters(new InputFilter[] {
new PasswordCharFilter(), new InputFilter.LengthFilter(20)
});
私はこの問題を抱えており、すでに設定されているフィルターを失うことなくプログラムでこれを行うための十分に説明された方法が欠けていると考えています。
XML での長さの設定:
受け入れられた回答が正しく述べているように、将来さらに変更しない EditText に固定長を定義する場合は、 EditText XML で定義するだけです。
android:maxLength="10"
プログラムによる長さの設定
プログラムで長さを設定するには、InputFilter
. ただし、新しい InputFilter を作成して に設定すると、EditText
XML またはプログラムで追加した他の定義済みフィルター (maxLines、inputType など) がすべて失われます。
したがって、これは間違っています:
editText.setFilters(new InputFilter[] {new InputFilter.LengthFilter(maxLength)});
以前に追加したフィルターが失われないようにするには、それらのフィルターを取得し、新しいフィルター (この場合は maxLength) を追加して、次のようにフィルターを元に戻す必要がありEditText
ます。
ジャワ
InputFilter[] editFilters = editText.getFilters();
InputFilter[] newFilters = new InputFilter[editFilters.length + 1];
System.arraycopy(editFilters, 0, newFilters, 0, editFilters.length);
newFilters[editFilters.length] = new InputFilter.LengthFilter(maxLength);
editText.setFilters(newFilters);
ただし、 Kotlinを使用すると誰にとっても簡単になりました。既存のフィルターにフィルターを追加する必要もありますが、次の簡単な方法で実現できます。
editText.filters += InputFilter.LengthFilter(maxLength)
TextView tv = new TextView(this);
tv.setFilters(new InputFilter[]{ new InputFilter.LengthFilter(250) });
これを達成する方法を知りたい人のために、これが私の拡張EditText
クラスEditTextNumeric
です。
.setMaxLength(int)
- 最大桁数を設定します
.setMaxValue(int)
- 最大整数値を制限する
.setMin(int)
- 最小整数値を制限する
.getValue()
- 整数値を取得
import android.content.Context;
import android.text.InputFilter;
import android.text.InputType;
import android.widget.EditText;
public class EditTextNumeric extends EditText {
protected int max_value = Integer.MAX_VALUE;
protected int min_value = Integer.MIN_VALUE;
// constructor
public EditTextNumeric(Context context) {
super(context);
this.setInputType(InputType.TYPE_CLASS_NUMBER);
}
// checks whether the limits are set and corrects them if not within limits
@Override
protected void onTextChanged(CharSequence text, int start, int before, int after) {
if (max_value != Integer.MAX_VALUE) {
try {
if (Integer.parseInt(this.getText().toString()) > max_value) {
// change value and keep cursor position
int selection = this.getSelectionStart();
this.setText(String.valueOf(max_value));
if (selection >= this.getText().toString().length()) {
selection = this.getText().toString().length();
}
this.setSelection(selection);
}
} catch (NumberFormatException exception) {
super.onTextChanged(text, start, before, after);
}
}
if (min_value != Integer.MIN_VALUE) {
try {
if (Integer.parseInt(this.getText().toString()) < min_value) {
// change value and keep cursor position
int selection = this.getSelectionStart();
this.setText(String.valueOf(min_value));
if (selection >= this.getText().toString().length()) {
selection = this.getText().toString().length();
}
this.setSelection(selection);
}
} catch (NumberFormatException exception) {
super.onTextChanged(text, start, before, after);
}
}
super.onTextChanged(text, start, before, after);
}
// set the max number of digits the user can enter
public void setMaxLength(int length) {
InputFilter[] FilterArray = new InputFilter[1];
FilterArray[0] = new InputFilter.LengthFilter(length);
this.setFilters(FilterArray);
}
// set the maximum integer value the user can enter.
// if exeeded, input value will become equal to the set limit
public void setMaxValue(int value) {
max_value = value;
}
// set the minimum integer value the user can enter.
// if entered value is inferior, input value will become equal to the set limit
public void setMinValue(int value) {
min_value = value;
}
// returns integer value or 0 if errorous value
public int getValue() {
try {
return Integer.parseInt(this.getText().toString());
} catch (NumberFormatException exception) {
return 0;
}
}
}
使用例:
final EditTextNumeric input = new EditTextNumeric(this);
input.setMaxLength(5);
input.setMaxValue(total_pages);
input.setMinValue(1);
EditText
もちろん、 に適用される他のすべてのメソッドと属性も機能します。
goto10の観察により、最大長を設定して他のフィルターが失われないように保護するために、次のコードをまとめました。
/**
* This sets the maximum length in characters of an EditText view. Since the
* max length must be done with a filter, this method gets the current
* filters. If there is already a length filter in the view, it will replace
* it, otherwise, it will add the max length filter preserving the other
*
* @param view
* @param length
*/
public static void setMaxLength(EditText view, int length) {
InputFilter curFilters[];
InputFilter.LengthFilter lengthFilter;
int idx;
lengthFilter = new InputFilter.LengthFilter(length);
curFilters = view.getFilters();
if (curFilters != null) {
for (idx = 0; idx < curFilters.length; idx++) {
if (curFilters[idx] instanceof InputFilter.LengthFilter) {
curFilters[idx] = lengthFilter;
return;
}
}
// since the length filter was not part of the list, but
// there are filters, then add the length filter
InputFilter newFilters[] = new InputFilter[curFilters.length + 1];
System.arraycopy(curFilters, 0, newFilters, 0, curFilters.length);
newFilters[curFilters.length] = lengthFilter;
view.setFilters(newFilters);
} else {
view.setFilters(new InputFilter[] { lengthFilter });
}
}
これを実現する別の方法は、次の定義を XML ファイルに追加することです。
<EditText
android:id="@+id/input"
android:layout_width="0dp"
android:layout_height="wrap_content"
android:inputType="number"
android:maxLength="6"
android:hint="@string/hint_gov"
android:layout_weight="1"/>
EditText
これにより、ウィジェットの最大長が 6 文字に制限されます。
material.ioから、以下TextInputEditText
と組み合わせて使用できますTextInputLayout
。
<com.google.android.material.textfield.TextInputLayout
android:layout_width="match_parent"
android:layout_height="wrap_content"
app:counterEnabled="true"
app:counterMaxLength="1000"
app:passwordToggleEnabled="false">
<com.google.android.material.textfield.TextInputEditText
android:id="@+id/edit_text"
android:hint="@string/description"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:maxLength="1000"
android:gravity="top|start"
android:inputType="textMultiLine|textNoSuggestions"/>
</com.google.android.material.textfield.TextInputLayout>
drawable を使用してパスワード EditText を構成できます。
または、カウンターの有無にかかわらずテキストの長さを制限できます。
依存:
implementation 'com.google.android.material:material:1.1.0-alpha02'
プログラムでJava用にこれを試してください:
myEditText(new InputFilter[] {new InputFilter.LengthFilter(CUSTOM_MAX_LEN)});
これは、Length フィルターを他のフィルターと共に使用できるようにするカスタム EditText クラスです。ティム・ギャラガーの回答に感謝します(以下)
import android.content.Context;
import android.text.InputFilter;
import android.util.AttributeSet;
import android.widget.EditText;
public class EditTextMultiFiltering extends EditText{
public EditTextMultiFiltering(Context context) {
super(context);
}
public EditTextMultiFiltering(Context context, AttributeSet attrs) {
super(context, attrs);
}
public EditTextMultiFiltering(Context context, AttributeSet attrs, int defStyleAttr) {
super(context, attrs, defStyleAttr);
}
public void setMaxLength(int length) {
InputFilter curFilters[];
InputFilter.LengthFilter lengthFilter;
int idx;
lengthFilter = new InputFilter.LengthFilter(length);
curFilters = this.getFilters();
if (curFilters != null) {
for (idx = 0; idx < curFilters.length; idx++) {
if (curFilters[idx] instanceof InputFilter.LengthFilter) {
curFilters[idx] = lengthFilter;
return;
}
}
// since the length filter was not part of the list, but
// there are filters, then add the length filter
InputFilter newFilters[] = new InputFilter[curFilters.length + 1];
System.arraycopy(curFilters, 0, newFilters, 0, curFilters.length);
newFilters[curFilters.length] = lengthFilter;
this.setFilters(newFilters);
} else {
this.setFilters(new InputFilter[] { lengthFilter });
}
}
}
コトリン:
edit_text.filters += InputFilter.LengthFilter(10)
ZTE Blade A520
不思議な効果があります。10 個を超える記号 (たとえば 15 個) を入力すると、EditText
最初の 10 個が表示されますが、他の 5 個は表示されておらず、アクセスできません。しかし、Backspace
でシンボルを削除すると、最初に右側の 5 つのシンボルが削除され、次に残りの 10 のシンボルが削除されます。この動作を克服するには、次の解決策を使用します。
android:inputType="textNoSuggestions|textVisiblePassword"
android:maxLength="10"
またはこれ:
android:inputType="textNoSuggestions"
またはこれ、提案が必要な場合:
private class EditTextWatcher(private val view: EditText) : TextWatcher {
private var position = 0
private var oldText = ""
override fun afterTextChanged(s: Editable?) = Unit
override fun beforeTextChanged(s: CharSequence?, start: Int, count: Int, after: Int) {
oldText = s?.toString() ?: ""
position = view.selectionStart
}
override fun onTextChanged(s: CharSequence?, start: Int, before: Int, count: Int) {
val newText = s?.toString() ?: ""
if (newText.length > 10) {
with(view) {
setText(oldText)
position = if (start > 0 && count > 2) {
// Text paste in nonempty field.
start
} else {
if (position in 1..10 + 1) {
// Symbol paste in the beginning or middle of the field.
position - 1
} else {
if (start > 0) {
// Adding symbol to the end of the field.
start - 1
} else {
// Text paste in the empty field.
0
}
}
}
setSelection(position)
}
}
}
}
// Usage:
editTextWatcher = EditTextWatcher(view.edit_text)
view.edit_text.addTextChangedListener(editTextWatcher)
android:maxLength="10"
EditTextで使用できます。(ここでは10文字までに制限されています)