36

所以我的应用程序中有一个按钮和一个编辑文本。当我单击按钮并在编辑文本中写入内容时,文本视图会发生变化。除了一件事之外,一切都按原样进行。我必须单击按钮两次才能使其工作(仅在我第一次打开活动时)。在我打开活动后第一次按下按钮并没有任何反应,之后它就可以正常工作了。

我已经对此进行了研究,据我所知,造成问题的原因是注意力集中,但我尝试了一些方法,但没有任何效果。

按钮 XML 代码:

<Button
    android:id="@+id/submitButton"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:layout_alignBaseline="@+id/editText1"
    android:layout_alignBottom="@+id/editText1"
    android:layout_alignLeft="@+id/checkBox25"
    android:text="@string/addMaterial"
    android:onClick="submitQuantityButton" >
</Button>

编辑文本 XML 代码:

<EditText
    android:id="@+id/editText1"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:layout_alignParentLeft="true"
    android:layout_below="@+id/spinner1"
    android:ems="3"
    android:inputType="number"
    android:maxLength="3" >
</EditText>

我尝试将 android:focusableInTouchMode="false" 添加到按钮 XML,我还尝试将 requestFocus 添加到按钮 XML,但它仍然不起作用。我还从 edittext 中删除了 requestFocus ,但它不起作用。我已经没有什么可以尝试的想法了。

onClick 方法:

public void submitQuantityButton (View v){
    Button submitButton = (Button)findViewById(R.id.submitButton);
    final Spinner sItems = (Spinner)findViewById(R.id.spinner1);
    final Context context = this;
    final CheckBox cb4 = (CheckBox) findViewById(R.id.checkBox4);
    final CheckBox cb5 = (CheckBox) findViewById(R.id.checkBox5);
    final CheckBox cb33 = (CheckBox) findViewById(R.id.checkBox33);
    final CheckBox cb30 = (CheckBox) findViewById(R.id.checkBox30);
    final CheckBox cb6 = (CheckBox) findViewById(R.id.checkBox6);
    final CheckBox cb7 = (CheckBox) findViewById(R.id.checkBox7);
    final CheckBox cb9 = (CheckBox) findViewById(R.id.checkBox9);
    final CheckBox cb10 = (CheckBox) findViewById(R.id.checkBox10);
    final CheckBox cb11 = (CheckBox) findViewById(R.id.checkBox11);
    final CheckBox cb12 = (CheckBox) findViewById(R.id.checkBox12);

    //
    final AlertDialog.Builder emptyETextErrorBuilder = new AlertDialog.Builder(context);
    emptyETextErrorBuilder.setTitle("Warning");
    emptyETextErrorBuilder.setMessage("Please enter a value before pressing this button");
    emptyETextErrorBuilder.setPositiveButton("OK", new DialogInterface.OnClickListener() {

        @Override
        public void onClick(DialogInterface dialog, int which) {
            dialog.cancel();
        }
    });

    submitButton.setOnClickListener(new View.OnClickListener() {

        @Override
        public void onClick(View v) {
            final int position = sItems.getSelectedItemPosition();
            EditText quantityEditText = (EditText)findViewById(R.id.editText1);

            switch (position){
            case 0:
                AlertDialog.Builder spinnerErrorBuilder = new AlertDialog.Builder(context);
                spinnerErrorBuilder.setTitle("Warning");
                spinnerErrorBuilder.setMessage("Please choose an item from the list above and then enter a certain value");
                spinnerErrorBuilder.setPositiveButton("OK", new DialogInterface.OnClickListener() {

                    @Override
                    public void onClick(DialogInterface dialog, int id) {
                        dialog.cancel();
                    }
                });
                AlertDialog spinnerError = spinnerErrorBuilder.create();
                spinnerError.show();
                break;
            case 1:
                String item1 = quantityEditText.getText().toString();
                if (item1.matches(""))
                {
                    AlertDialog emptyETextError = emptyETextErrorBuilder.create();
                    emptyETextError.show();
                }
                else
                {
                    cb4.setText("Elaborate Totem (" + item1 + "/250)");
                }
                break;
            case 2:
                String item2 = quantityEditText.getText().toString();
                if (item2.matches(""))
                {
                    AlertDialog emptyETextError = emptyETextErrorBuilder.create();
                    emptyETextError.show();
                }
                else
                {
                    cb5.setText("Pile of Crystalline Dust (" + item2 + "/250)");
                }
                break;
            case 3:
                String item3 = quantityEditText.getText().toString();
                if (item3.matches(""))
                {
                    AlertDialog emptyETextError = emptyETextErrorBuilder.create();
                    emptyETextError.show();
                }
                else
                {
                    cb33.setText("Pile of Crystalline Dust (" + item3 + "/250)");
                }
                break;
            case 4:
                String item4 = quantityEditText.getText().toString();
                if (item4.matches(""))
                {
                    AlertDialog emptyETextError = emptyETextErrorBuilder.create();
                    emptyETextError.show();
                }
                else
                {
                    cb30.setText("Pile of Crystalline Dust (" + item4 + "/250)");
                }
                break;
            case 5:
                String item5 = quantityEditText.getText().toString();
                if (item5.matches(""))
                {
                    AlertDialog emptyETextError = emptyETextErrorBuilder.create();
                    emptyETextError.show();
                }
                else
                {
                    cb6.setText("Powerful Venom Sac (" + item5 + "/250)");
                }
                break;
            case 6:
                String item6 = quantityEditText.getText().toString();
                if (item6.matches(""))
                {
                    AlertDialog emptyETextError = emptyETextErrorBuilder.create();
                    emptyETextError.show();
                }
                else
                {
                    cb7.setText("Vial of Powerful Blood (" + item6 + "/250)");
                }
                break;
            case 7:
                String item7 = quantityEditText.getText().toString();
                if (item7.matches(""))
                {
                    AlertDialog emptyETextError = emptyETextErrorBuilder.create();
                    emptyETextError.show();
                }
                else
                {
                    cb9.setText("Ancient Bone (" + item7 + "/250)");
                }
                break;
            case 8:
                String item8 = quantityEditText.getText().toString();
                if (item8.matches(""))
                {
                    AlertDialog emptyETextError = emptyETextErrorBuilder.create();
                    emptyETextError.show();
                }
                else
                {
                    cb10.setText("Armored Scale (" + item8 + "/250)");
                }
                break;
            case 9:
                String item9 = quantityEditText.getText().toString();
                if (item9.matches(""))
                {
                    AlertDialog emptyETextError = emptyETextErrorBuilder.create();
                    emptyETextError.show();
                }
                else
                {
                    cb11.setText("Vicious Claw (" + item9 + "/250)");
                }
                break;
            case 10:
                String item10 = quantityEditText.getText().toString();
                if (item10.matches(""))
                {
                    AlertDialog emptyETextError = emptyETextErrorBuilder.create();
                    emptyETextError.show();
                }
                else
                {
                    cb12.setText("Vicious Fang (" + item10 + "/250)");
                }
                break;
            }
        }
    });
}
4

8 回答 8

50

我的问题是ButtonXML 定义:

android:focusableInTouchMode="true"

删除此属性,按钮不需要被触摸两次。似乎第一次触摸被消耗以将焦点分配在按钮上,然后第二次触发OnClickListener.

请注意,按钮可以正常使用该android:focusable="true"属性。

于 2015-11-05T04:27:53.717 回答
8

好的,所以我终于自己弄清楚了导致问题的原因。我不敢相信我错过了这么明显的问题。导致问题的不是焦点,而是方法本身。在我的 XML 文件中,我通过 android:onClick="onClick" 调用了 onClick 方法,然后我还在 onClick 方法中添加了一个按钮监听器到 java 代码中。

我所做的只是删除按钮监听器,不再需要双击!因此,如果将来有人遇到此问题,只需确保您没有同时使用 onClick 方法和按钮侦听器。

错误代码:

public void submitQuantityButton (View v){

submitButton.setOnClickListener(new View.OnClickListener() {

    @Override
    public void onClick(View v) {
.
.
. //REST OF THE CODE

为了让它工作,我只是删除了 onclick 监听器,只留下:

public void submitQuantityButton (View v){
.
.
. //REST OF THE CODE
于 2013-06-26T13:37:18.573 回答
2

如果您将视图膨胀到另一个视图,请尝试在父视图上设置:

view.setFocusable(false);

为我工作。

于 2017-09-01T23:18:16.100 回答
2

有时我在片段上单击btntxtedt时遇到问题,并且确实有助于使用.setOnClickListener()需要.setOnTouchListener,如下例所示:

txtClose.setOnTouchListener((v, event) -> {
                // do staff...
                return false;
            });
于 2017-10-18T09:42:30.637 回答
0

试试这个一次
更新

override onResume在您的方法中activity ,然后从您的编辑文本中清除焦点并将焦点设置到您的主布局

edittext.clearFocus();
layout.requestFocus();

或者

button.requestFocus();

如果问题出在虚拟键盘上,它可能会对您有所帮助

在你的AndroidManifest.xml文件里面你的Activity标签把这一行

android:windowSoftInputMode="stateHidden"
于 2013-06-23T14:49:51.977 回答
0

我和OP有同样的问题。我尝试了所有与焦点相关的建议,但没有一个每次都对我有用。

我尝试NavigationDrawer从我的布局中删除,但这没有用。

最后,我尝试用CoordinatorLayouta替换我的LinearLayout按钮,现在我的按钮每次都单击第一次。可能值得一试。

于 2017-02-07T14:38:47.923 回答
0

通过添加以下行:

 <Button
    android:id="@+id/sauvegarder"
    android:text="Sauvegarder"
    android:layout_gravity="center"
    android:background="@color/colorAccent"
    android:layout_margin="@dimen/fontmargin"
    style="@style/edit"
    android:gravity="center"
    android:textColor="@color/colorPrimary"
    android:layout_width="220dp"
    android:layout_height="wrap_content"
    android:focusableInTouchMode="false"
    />

在我的 xml 文件中它完美地工作!

于 2020-05-17T17:08:50.857 回答
-1

只需使用 getText() 从 EditText 获取文本,然后使用 setText() 设置 TextView 的文本。

于 2013-06-23T14:55:31.463 回答