android - 阻止EditText在Activity啟動時獲得關注




15 Answers

Luc和Mark的優秀答案卻缺少一個好的代碼示例。 將標記android:focusableInTouchMode="true"<LinearLayout> ,如下例所示將解決問題。

<!-- Dummy item to prevent AutoCompleteTextView from receiving focus -->
<LinearLayout
    android:focusable="true" 
    android:focusableInTouchMode="true"
    android:layout_width="0px" 
    android:layout_height="0px"/>

<!-- :nextFocusUp and :nextFocusLeft have been set to the id of this component
to prevent the dummy from receiving focus again -->
<AutoCompleteTextView android:id="@+id/autotext"
    android:layout_width="fill_parent" 
    android:layout_height="wrap_content"
    android:nextFocusUp="@id/autotext" 
    android:nextFocusLeft="@id/autotext"/>

我在Android中有一個Activity ,有兩個元素:

  1. EditText
  2. ListView

當我的Activity啟動時, EditText立即具有輸入焦點(閃爍光標)。 我不希望任何控件在啟動時具有輸入焦點。 我試過了:

EditText.setSelected(false);

沒運氣。 如何在Activity開始時說服EditText不選擇自己?




存在更簡單的解決方案。 在父佈局中設置這些屬性:

<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:id="@+id/mainLayout"
    android:descendantFocusability="beforeDescendants"
    android:focusableInTouchMode="true" >

現在,當活動開始時,此主要佈局將默認獲得焦點。

此外,我們可以通過再次將焦點放在主佈局上,在運行時從子視圖中刪除焦點(例如,在完成子編輯之後),如下所示:

findViewById(R.id.mainLayout).requestFocus();

Guillaume Perrot的 好評

android:descendantFocusability="beforeDescendants"似乎是默認值(整數值為0)。 它只是通過添加android:focusableInTouchMode="true"

實際上,我們可以看到beforeDescendantsViewGroup.initViewGroup()方法(Android 2.2.2)中設置為默認值。 但不等於0. ViewGroup.FOCUS_BEFORE_DESCENDANTS = 0x20000;

感謝紀堯姆。




問題似乎來自於我只能在佈局的XML form中看到的屬性。

確保在EditText XML標記內的聲明末尾刪除此行:

<requestFocus />

這應該是這樣的:

<EditText
   android:id="@+id/emailField"
   android:layout_width="fill_parent"
   android:layout_height="wrap_content"
   android:inputType="textEmailAddress">

   //<requestFocus /> /* <-- without this line */
</EditText>



以下內容將阻止edittext在創建時獲得焦點,但在觸摸時抓住它。

<EditText
    android:id="@+id/et_bonus_custom"
    android:focusable="false" />

所以你在xml中將focusable設置為false,但關鍵是在java中,你添加了以下監聽器:

etBonus.setOnTouchListener(new View.OnTouchListener() {
    @Override
    public boolean onTouch(View v, MotionEvent event) {
        v.setFocusable(true);
        v.setFocusableInTouchMode(true);
        return false;
    }
});

因為您返回false,即不消耗該事件,所以聚焦行為將像平常一樣進行。




我曾單獨嘗試了幾個答案,但重點仍然是EditText。 我只是通過使用以下兩個解決方案來設法解決它。

<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
  android:id="@+id/mainLayout"
  android:descendantFocusability="beforeDescendants"
  android:focusableInTouchMode="true" >

(來自Silver的參考https://.com/a/8639921/15695 )

並刪除

 <requestFocus />

在EditText

(參考文獻floydaddict share )




簡單的解決方案:在AndroidManifest中使用Activity標籤

android:windowSoftInputMode="stateAlwaysHidden"



以下在Manifest為我工作。 寫,

<activity
android:name=".MyActivity"
android:windowSoftInputMode="stateAlwaysHidden"/>



Manifest.xml文件的activity標記中添加android:windowSoftInputMode="stateAlwaysHidden"

Source




如果您的活動有另一個視圖,如ListView ,您還可以:

ListView.requestFocus(); 

在你的onResume()中從editText獲取焦點。

我知道這個問題已經得到解答,但只是提供了一個對我有用的替代解決方案:)




onCreate方法中添加以下內容:

this.getWindow().setSoftInputMode(WindowManager.LayoutParams.SOFT_INPUT_STATE_ALWAYS_HIDDEN);



由於我不喜歡用與功能相關的東西污染XML,我創建了這個方法,“透明地”從第一個可聚焦視圖中竊取焦點,然後確保在必要時自行移除!

public static View preventInitialFocus(final Activity activity)
{
    final ViewGroup content = (ViewGroup)activity.findViewById(android.R.id.content);
    final View root = content.getChildAt(0);
    if (root == null) return null;
    final View focusDummy = new View(activity);
    final View.OnFocusChangeListener onFocusChangeListener = new View.OnFocusChangeListener()
    {
        @Override
        public void onFocusChange(View view, boolean b)
        {
            view.setOnFocusChangeListener(null);
            content.removeView(focusDummy);
        }
    };
    focusDummy.setFocusable(true);
    focusDummy.setFocusableInTouchMode(true);
    content.addView(focusDummy, 0, new LinearLayout.LayoutParams(0, 0));
    if (root instanceof ViewGroup)
    {
        final ViewGroup _root = (ViewGroup)root;
        for (int i = 1, children = _root.getChildCount(); i < children; i++)
        {
            final View child = _root.getChildAt(i);
            if (child.isFocusable() || child.isFocusableInTouchMode())
            {
                child.setOnFocusChangeListener(onFocusChangeListener);
                break;
            }
        }
    }
    else if (root.isFocusable() || root.isFocusableInTouchMode())
        root.setOnFocusChangeListener(onFocusChangeListener);

    return focusDummy;
}



在父佈局中寫下這一行......

 android:focusableInTouchMode="true"



這是最完美,最簡單的解決方案。我總是在我的應用程序中使用它。

getWindow().setSoftInputMode(WindowManager.LayoutParams.SOFT_INPUT_STATE_HIDDEN);



將此代碼寫入您不想打開鍵盤的Activity中的Manifest文件中。

android:windowSoftInputMode="stateHidden"

清單文件:

 <?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
    package="com.example.projectt"
    android:versionCode="1"
    android:versionName="1.0" >

    <uses-sdk
        android:minSdkVersion="8"
        android:targetSdkVersion="24" />

    <application
        android:allowBackup="true"
        android:icon="@drawable/ic_launcher"
        android:label="@string/app_name"
        android:theme="@style/AppTheme" >
         <activity
            android:name=".Splash"
            android:label="@string/app_name" >
            <intent-filter>
                <action android:name="android.intent.action.MAIN" />

                <category android:name="android.intent.category.LAUNCHER" />
            </intent-filter>
        </activity>
        <activity
            android:name=".Login"
            **android:windowSoftInputMode="stateHidden"**
            android:label="@string/app_name" >
        </activity>

    </application>

</manifest>



在Activity的onCreate中,只需在EditText元素上添加clearFocus() 。 例如,

edittext = (EditText) findViewById(R.id.edittext);
edittext.clearFocus();

如果你想將焦點轉移到另一個元素,請使用requestFocus() 。 例如,

button = (Button) findViewById(R.id.button);
button.requestFocus();



Related