2

機能する EditText フィールドのコードがいくつかありますが、フォーカスを変更するとこのエラーがログに記録されます (フォーカスは必要に応じて変更されます)。

InputEventConsistencyVerifier      KeyEvent: ACTION_UP but key was not  down

誰かが理由を説明してもらえますか?

このエラーを作成する InputEventConsistencyVerifier ソースを読みましたが、どのように発生するのかわかりません。list.requestFocus() を削除してみました。しかし、その行がなければ、フォーカスは EditText フィールドにとどまります。ただし、行を削除すると、ログのエラーはなくなります。

public class AddDeleteActivity extends FragmentActivity {

private final String TAG = "AddDeleteName";

/*
 * (non-Javadoc)
 * 
 * @see android.app.Activity#onCreate(android.os.Bundle)
 */
@Override
protected void onCreate(Bundle savedInstanceState) {
    // TODO Auto-generated method stub
    super.onCreate(savedInstanceState);

    Log.e(TAG, "about to load fragment");

    setContentView(R.layout.add_delete_child_layout);

    Log.e(TAG, "finished loading fragment");

    final EditText nameTextField = (EditText) findViewById(R.id.new_child);

    nameTextField
            .setOnEditorActionListener(new OnEditorActionListener() {

                @Override
˚               public boolean onEditorAction(TextView v, int    actionId,
                        KeyEvent event) {

                    Log.e(TAG, "onEditorAction: " + actionId);

                    String name = nameTextField.getText()
                            .toString();

                    Log.e(TAG, " name: " + name);

                    InputMethodManager inputManager = (InputMethodManager) v
                            .getContext().getSystemService(
                                    Context.INPUT_METHOD_SERVICE);
                    inputManager.hideSoftInputFromWindow(
                            v.getWindowToken(), 0);

                    Log.e(TAG, "change focus to List");
                    View list = findViewById(R.id.modchild_fragment);

 /*** FOLLOWING LINE GENERATES ERROR *****/
                    list.requestFocus();

                    return false;
                }
            });

}

}

.xml:

<fragment
    xmlns:android="http://schemas.android.com/apk/res/android"
    android:id="@+id/modchild_fragment"
    android:name="com.projectx.control.AddDeleteChild"
    android:layout_width="match_parent"
    android:layout_height="wrap_content" >
</fragment>

<EditText
    android:id="@+id/new_child"
    android:layout_width="fill_parent"
    android:layout_height="wrap_content"
    android:hint="enter launch codes"
    android:imeOptions="actionDone"
    android:inputType="text"
    android:singleLine="true" />

ありがとう!

4

1 に答える 1

2

まず、 を呼び出す代わりにlist.requestFocusを使用するnameTextField.clearFocusと、実行しようとしていることをより正確に伝えることができます。

今、私はこの特定のエラーの詳細をすべて知っているわけではありませんが、私の推測では、またはイベントメッセージonEditorActionの処理内で TextView によって同期的に呼び出されます。他の場所で呼び出すと、キー押下の通常のイベント フローが中断される可能性があります。繰り返しますが、それは単なる推測です。ACTION_DOWNACTION_UPrequestFocus

あなたができることは、list.requestFocus呼び出しを でラップしRunnable、 を使用して実行可能なイベントループに投稿することHandler.post(Runnable)です。一般的なパターンは、UI クラス (フラグメントやアクティビティなど) で Handler を含むプライベート フィールドを次のように保持することです。

Handler mHandler = new Handler();
...
mHandler.post(...);

これにより、現在のイベント/メッセージの処理が終了し、Runnable のみが実行されます (この場合、list.requestFocus現在投稿されている他のすべてのメッセージが処理された後に への呼び出しが行われます (通常、これはわずか数ミリ秒です))。

上で述べたように、clearFocus代わりに使用してみてください。

于 2012-10-15T16:35:34.323 に答える