android实现自定义软键盘,先上图看效果,效果基本上是仿ios输入法实现的
这里是实现隐藏系统输入法,同时让EditText能获取光标的代码部分(通过反射调用):
<span style="font-size:18px;">keyBoardLabel = (EditText) rootView
.findViewById(R.id.wifi_key_input_edittext);
// this.getActivity()
// .getWindow()
// .setSoftInputMode(
// WindowManager.LayoutParams.SOFT_INPUT_STATE_ALWAYS_HIDDEN);
try {
Class<EditText> cls = EditText.class;
Method setShowSoftInputOnFocus;
setShowSoftInputOnFocus = cls.getMethod("setShowSoftInputOnFocus",
boolean.class);
setShowSoftInputOnFocus.setAccessible(true);
setShowSoftInputOnFocus.invoke(keyBoardLabel, false);
} catch (Exception e) {
e.printStackTrace();
}</span>
先看XML文件: 这里使用到了ViewStub,为了不用一次性加载 过多的布局文件资源.ViewStub能更省内存!!
<span style="font-size:18px;"><?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="320dp"
android:layout_height="320dp"
android:background="@drawable/wifi_key_bg"
android:clickable="true"
android:gravity="center_horizontal"
android:orientation="vertical" >
<ImageView
android:id="@+id/wifi_keyboard_exit"
style="@style/Exit"
android:src="@drawable/wifi_key_return" />
<!-- keyboard view -->
<LinearLayout
android:layout_width="320dp"
android:layout_height="0dp"
android:layout_weight="1"
android:orientation="vertical"
android:paddingLeft="29dp"
android:paddingRight="29dp" >
<!-- keyboard top -->
<LinearLayout
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_marginTop="2dp"
android:gravity="center"
android:paddingBottom="3dp" >
<ImageButton
android:id="@+id/wifi_key_lpage_btn"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:background="@drawable/wifi_key_lpage" />
<EditText
android:id="@+id/wifi_key_input_edittext"
android:layout_width="150dp"
android:layout_height="wrap_content"
android:layout_marginLeft="5dp"
android:layout_marginRight="5dp"
android:background="@drawable/wifi_key_edit_bg"
android:gravity="center"
android:singleLine="true"
android:text=""
android:textCursorDrawable="@drawable/edittext_cursor" />
<ImageButton
android:id="@+id/wifi_key_rpage_btn"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:background="@drawable/wifi_key_rpage" />
</LinearLayout>
<!-- true key board include other layout -->
<ViewStub
android:id="@+id/key_board_input_lower_viewstub"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout="@layout/key_board_lower_layout"
android:paddingBottom="3dp"
android:visibility="gone" />
<ViewStub
android:id="@+id/key_board_input_upper_viewstub"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout="@layout/key_board_upper_layout"
android:paddingBottom="3dp"
android:visibility="gone" />
<ViewStub
android:id="@+id/key_board_input_number_viewstub"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:inflatedId="@+id/inflatedStart"
android:layout="@layout/key_board_number"
android:paddingBottom="3dp"
android:visibility="gone" />
<ViewStub
android:id="@+id/key_board_input_symbol1_viewstub"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:inflatedId="@+id/inflatedStart"
android:layout="@layout/key_board_symbol_1"
android:paddingBottom="3dp"
android:visibility="gone" />
<ViewStub
android:id="@+id/key_board_input_symbol2_viewstub"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:inflatedId="@+id/inflatedStart"
android:layout="@layout/key_