当前位置: 首页 > 知识库问答 >
问题:

请求另一个EditText的焦点行为异常

慕阳平
2023-03-14

我有四个编辑文本来读取PIN。现在,我已经对EditText的Java端进行了编码,它的行为异常。在第一个编辑文本中输入一位数字后,它应该请求第二个编辑文本的焦点,但它会转到第三个编辑文本。

更重要的是,它被定义为numberPassword,并且数字仍然可见。

这是布局文件的源代码:

 <RelativeLayout
    android:layout_centerInParent="true"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content">
<EditText
    android:id="@+id/mpin_1"
    android:layout_marginStart="20dp"
    android:layout_centerVertical="true"
    android:maxLength="1"
    android:gravity="center"
    android:layout_width="50dp"
    android:inputType="numberPassword"
    android:layout_height="50dp" />

<EditText
    android:id="@+id/mpin_2"
    android:layout_marginStart="20dp"
    android:layout_toEndOf="@+id/mpin_1"
    android:layout_centerVertical="true"
    android:gravity="center"
    android:maxLength="1"
    android:layout_width="50dp"
    android:inputType="numberPassword"
    android:layout_height="50dp" />

<EditText
    android:id="@+id/mpin_3"
    android:layout_marginStart="20dp"
    android:layout_toEndOf="@+id/mpin_2"
    android:layout_centerVertical="true"
    android:gravity="center"
    android:layout_width="50dp"
    android:maxLength="1"
    android:inputType="numberPassword"
    android:layout_height="50dp" />

<EditText
    android:id="@+id/mpin_4"
    android:layout_marginStart="20dp"
    android:layout_toEndOf="@+id/mpin_3"
    android:gravity="center"
    android:layout_centerVertical="true"
    android:layout_width="50dp"
    android:maxLength="1"
    android:inputType="numberPassword"
    android:layout_height="50dp" />

</RelativeLayout>

java文件的源代码

    public class SpinActivity extends AppCompatActivity
{
    private StringBuilder s_pin;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_spin);
        s_pin = new StringBuilder();
        s_pin.setLength(0);

        Button sPinButton = (Button)findViewById(R.id.set_s_pin_button);

        final EditText e1 = (EditText)findViewById(R.id.mpin_1);
        final EditText e2 = (EditText)findViewById(R.id.mpin_2);
        final EditText e3 = (EditText)findViewById(R.id.mpin_3);
        final EditText e4 = (EditText)findViewById(R.id.mpin_4);

        e1.setOnKeyListener(new View.OnKeyListener() {
            @Override
            public boolean onKey(View v, int keyCode, KeyEvent event)
            {
                if(e1.getText().length()==1)
                    s_pin.append(e1.getText().toString());
                //e1.setEnabled(false);
                e2.requestFocus();
                return false;
            }
        });

        e2.setOnKeyListener(new View.OnKeyListener() {
            @Override
            public boolean onKey(View v, int keyCode, KeyEvent event)
            {
                if(e2.getText().length()==1)
                    s_pin.append(e2.getText().toString());
                //e2.setEnabled(false);
                e3.requestFocus();
                return false;
            }
        });

        e3.setOnKeyListener(new View.OnKeyListener() {
            @Override
            public boolean onKey(View v, int keyCode, KeyEvent event)
            {
                if(e3.getText().length()==1)
                    s_pin.append(e3.getText().toString());
                //e3.setEnabled(false);
                e4.requestFocus();
                return false;
            }
        });

        e4.setOnKeyListener(new View.OnKeyListener() {
            @Override
            public boolean onKey(View v, int keyCode, KeyEvent event)
            {
                if(e4.getText().length()==1)
                    s_pin.append(e4.getText().toString());
               // e4.setEnabled(false);
                return false;
            }
        });

        sPinButton.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v)
            {
                Toast.makeText(getApplicationContext(),s_pin.toString(),
                        Toast.LENGTH_SHORT).show();

            }
        });



    }


}

如何解决这个问题?

共有1个答案

孙朗
2023-03-14

使用以下代码:

android:nextFocusDown="@+id/edittext"

edittext是要聚焦的编辑文本的ID。

 类似资料:
  • 我有一个和一个。点击按钮,我想打开键盘,同时请求关注,以便用户直接开始在键盘上键入文本,并出现在中。但是在我的例子中,当我点击按钮时,它会打开键盘,但它不会将焦点设置在上,因为用户必须再次单击才能在上面写入。问题是什么。任何帮助或建议。 单击按钮时的代码

  • 问题内容: 我是Python的新手,正在尝试使用Tkinter创建一个简单的GUI。 因此,在许多用户界面中,单击选项卡按钮通常会将焦点从一个Text小部件更改为另一个。每当我在“文本”小部件中时,选项卡只会缩进文本光标。 有人知道这是否可配置吗? 问题答案: 使用Tkinter可以很容易地做到这一点。 要使此工作生效,必须完成几件事。首先,您需要确保标准行为 不会 发生。也就是说,您不希望标签页

  • 我有一个EditText-Field,并为它设置了一个OnFocusChangeListener。当它失去焦点时,将调用一个方法,该方法用数据库中的EditText检查EditText的值。如果方法的return-value为true,则显示一个toast并且焦点应该再次回到EditText上。焦点应该总是回到EditText上,键盘应该显示,直到方法的return-value为false。 ed

  • 我正在尝试发送一个经过身份验证的请求,只需点击邮递员。 所以,我有一个名为“Oauth”的请求,我正在使用测试将令牌存储在局部变量中。 我现在要做的是,对于需要承载令牌的任何其他请求,自动运行Oauth请求(从预请求脚本)。 有没有一种方法可以通过单击邮递员按钮来获取访问令牌并发送经过身份验证的请求?

  • 我尽力描述我的处境。我的wicket站点包含list wicket组件,其中每个列表元素都有另一个列表。最低级别列表中的每个元素都有下载某个文件的ajax wicket链接。这一切都很好。我习惯了这种懒散的行为。此行为的方法startDownload在link onClick方法中调用。

  • 如何在JMETER中创建一个测试,该测试将: 总共提出100个请求,但是使 每4次请求站点A和 每5次请求站点B