如何實現軟鍵盤不自動彈出,使用的方法是設置android:windowSoftInputMode屬性。那麼,這個屬性究竟是幹什麼的,他有什麼做用呢?今天這篇文章,就是探索android:windowSoftInputMode屬性的做用的。android
首先,咱們從這個屬性的名稱中,能夠很直觀的看出它的做用,這個屬性就是來設置窗口軟鍵盤的交互模式的。佈局
android:windowSoftInputMode屬性一共有9個取值,分別是:測試
stateUnspecified,stateUnchanged,stateHidden,stateAlwaysHidden,stateVisible,stateAlwaysVisible,adjustUnspecified,adjustResize,adjustPan。.net
咱們設置屬性的時候,能夠在這9個值裏面選擇一個,也能夠用"state...|adjust"的形式進行設置。那麼,這些取值究竟是怎麼影響到軟鍵盤與窗口之間的交互的呢?下面,咱們就一個個的測試這9個取值,究竟是如何影響軟鍵盤的顯示的。3d
1.stateUnspecifiedcode
中文意思是未指定狀態,當咱們沒有設置android:windowSoftInputMode屬性的時候,軟件默認採用的就是這種交互方式,系統會根據界面採起相應的軟鍵盤的顯示模式,好比,當界面上只有文本和按鈕的時候,軟鍵盤就不會自動彈出,由於沒有輸入的必要。那麼,當界面上出現了獲取了焦點的輸入框的時候,軟鍵盤會不會自動的彈出呢?這個還真不必定!好比,在下面的這個界面佈局中,軟鍵盤並不會自動彈出。xml
就是說,默認的,在這種界面狀況下,系統並不肯定用戶是否須要軟鍵盤,所以不會自動彈出。可是,爲何說不必定呢?這是由於,若是咱們在這個佈局的外面,包裹上一個htm
ScrollView,軟鍵盤就會自動的彈出來了!blog
以下,在這種佈局文件下,軟鍵盤會自動的彈出ci
這確實是一個很奇怪的判斷方式。所以,咱們能夠得出結論,當設置屬性爲stateUnspecified的時候,系統是默認不彈出軟鍵盤的,可是當有得到焦點的輸入框的界面有滾動的需求的時候,會自動彈出軟鍵盤。至於爲何非要強調要獲取焦點的輸入框,這是由於,若是不是輸入框獲取焦點,軟鍵盤也是不會自動彈出的,讓界面不自動彈出軟鍵盤的其中一個解決方案,就是在xml文件中,設置一個非輸入框控件獲取焦點,從而阻止鍵盤彈出。
2.stateUnchanged
中文的意思就是狀態不改變的意思,咱們應該怎麼理解這句話呢?其實很好理解,就是說,當前界面的軟鍵盤狀態,取決於上一個界面的軟鍵盤狀態。舉個例子,假如當前界面鍵盤是隱藏的,那麼跳轉以後的界面,軟鍵盤也是隱藏的;若是當前界面是顯示的,那麼跳轉以後的界面,軟鍵盤也是顯示狀態。
3.stateHidden
顧名思義,若是咱們設置了這個屬性,那麼鍵盤狀態必定是隱藏的,無論上個界面什麼狀態,也無論當前界面有沒有輸入的需求,反正就是不顯示。所以,咱們能夠設置這個屬性,來控制軟鍵盤不自動的彈出。
4.stateAlwaysHidden
這個屬性也可讓軟鍵盤隱藏,可是我暫時還不知道和stateHidden屬性的區別,原本想去stackOverFlow上問一下的,可是,Great Wall,呵呵呵...祝願病魔早日打敗方校長
5.stateVisible
設置爲這個屬性,能夠將軟鍵盤召喚出來,即便在界面上沒有輸入框的狀況下也能夠強制召喚出來。
6.stateAlwaysVisible
這個屬性也是能夠將鍵盤召喚出來,可是與stateVisible屬性有小小的不一樣之處。舉個例子,當咱們設置爲stateVisible屬性,若是當前的界面鍵盤是顯示的,當咱們點擊按鈕跳轉到下個界面的時候,軟鍵盤會由於輸入框失去焦點而隱藏起來,當咱們再次回到當前界面的時候,鍵盤這個時候是隱藏的。可是若是咱們設置爲stateAlwaysVisible,咱們跳轉到下個界面,軟鍵盤仍是隱藏的,可是當咱們再次回來的時候,軟鍵盤是會顯示出來的。因此,這個Always就解釋了這個區別,無論什麼狀況到達當前界面(正常跳轉或者是上一個界面被用戶返回),軟鍵盤都是顯示狀態。
說到這裏,我聯想到了上面的stateHidden和stateAlwaysHidden,我估計區別也是這樣的,就是說,stateAlwaysHidden不管如何都是隱藏的,可是若是在跳轉到下個界面的時候,軟鍵盤被召喚出來了,那麼當下個界面被用戶返回的時候,鍵盤應該是不會被隱藏的,可是,我尚未找到可以跳轉到下個界面,還讓當前界面軟鍵盤不消失的方法,因此暫時不能驗證。
7.adjustUnspecified
從這個屬性開始,就不是設置軟鍵盤的顯示與隱藏模式了,而是設置軟鍵盤與軟件的顯示內容之間的顯示關係。當你跟咱們沒有設置這個值的時候,這個選項也是默認的設置模式。在這中狀況下,系統會根據界面選擇不一樣的模式。若是界面裏面有能夠滾動的控件,好比ScrowView,系統會減少能夠滾動的界面的大小,從而保證即便軟鍵盤顯示出來了,也可以看到全部的內容。若是佈局裏面沒有滾動的控件,那麼軟鍵盤可能就會蓋住一些內容,咱們從下面的圖中能夠看出差異。
沒有滾動控件,軟鍵盤下面的佈局都被遮擋住了,若想修改,只能隱藏軟鍵盤,而後選擇。並且,重點注意一下上面的佈局,當咱們選擇的輸入框偏下的時候,上面的標題欄和佈局被軟鍵盤頂上去了。記住這個特徵,由於後面有個屬性和這個的效果不同。
佈局裏面有滑動控件,系統會自動的縮小整個界面的大小,所以,咱們能夠軟鍵盤上面的小區域中顯示全部的輸入框。
這就是兩中顯示模式之間的差異。
8.adjustResize
這個屬性表示Activity的主窗口老是會被調整大小,從而保證軟鍵盤顯示空間。
咱們先看顯示效果。
注意觀察這個上面的標題欄和按鈕,設置爲adjustResize屬性以後,對於沒有滑動控件的佈局,雖然仍是不能選擇全部的輸入框,可是,窗口的顯示方式發生了變化,默認屬性時,整個佈局是被頂上去了,可是設置爲adjustResize屬性,佈局的位置並無發生什麼變化,這就是最大的區別。
而對於有滑動控件的佈局來講,顯示效果和默認是同樣的。
9.adjustPan
若是設置爲這個屬性,那麼Activity的屏幕大小並不會調整來保證軟鍵盤的空間,而是採起了另一種策略,系統會經過佈局的移動,來保證用戶要進行輸入的輸入框確定在用戶的失業範圍裏面,從而讓用戶能夠看到本身輸入的內容。對於沒有滾動控件的佈局來講,這個其實就是默認的設置,若是咱們選擇的位置偏下,上面的標題欄和部分控件會被頂上去。可是對於有滾動控件的佈局來講,則不太同樣,咱們看下面的效果圖。
首先,這是軟鍵盤沒有彈出的時候,有滾動控件的顯示範圍,最下面顯示的是9.
當咱們點擊5這個輸入框,咱們會發現下面的現象。
最上面只可以顯示到按鈕,標題欄已經不能看到了。
而最下面也只能滑動到8,下面的內容也不可以滑動了。
所以,咱們就可以理解這個屬性的做用了。
經過以上的實驗,咱們能夠得出結論,若是咱們不設置"adjust..."的屬性,對於沒有滾動控件的佈局來講,採用的是adjustPan方式,而對於有滾動控件的佈局,則是採用的adjustResize方式。
瞭解了上面的這些知識以後,咱們就能夠根據本身的需求設置不一樣的方式了。並且,關於如何使得界面加載的時候不顯示軟鍵盤,咱們也有了一個很清楚的認識。
來源:http://www.jb51.net/article/56043.htm