焦点问题总结

一、什么是焦点

button获取焦点的话就是橙色,edittext获取焦点是竖线,等等这些是焦点。

二、关于焦点的说明

触摸事件可能要触发多次,但点击事件可能就一次。触摸事件在先,点击事件在后。

在触摸事件中如果return false那么点击事件也没有。

三、焦点顺序及切换的问题。

默认情况下,默认情况下,按而已自上而下获取焦点,但是我们也可以自定义来控制获取焦点的顺序

强制性的获取焦点就是三句话,缺一不可:获取焦点

btnSearch.setFocusable(true)

btnSearch.setFocusableInTouchMode(true);在Touch模式下获取焦点需要设置focusableInTouchMode为true。

btnSearch.requestFocus();

setFocusable( false);肯定就是没有获取焦点的资格。

所以不管怎么弄,都不会有焦点,但是触摸事件与点击事件正常使用。只不过焦点不显示而已。

四、关于editext获取焦点的问题

默认情况下,默认情况下,按而已自上而下获取焦点,但edittext具有较高的获取焦点的优先权,即使它在下面,它也可能先获取焦点,那么如果不让其获取焦点,则setfoucable(false),永远也获取不到焦点资格,触摸,点击都不获取焦点。那么只是让默认不获取焦点,而点击或触摸获取焦点,怎么办?

在EditText前面放置一个看不到的LinearLayout,让它率先获取焦点,代码如下:

<LinearLayout android:focusable="true" android:focusableInTouchMode="true"

当我们键盘有上下左右键的时候

android:nextFocusUp- 定义当点up键时,哪个控件将获得焦点

android:nextFocusDown-定义当点down键时,哪个控件将获得焦点

android:nextFocusLeft-定义当点left键时,哪个控件将获得焦点

android:nextFocusRight--定义当点right键时,哪个控件将获得焦点

触摸事件发生时,edittext如果没有焦点会获取焦点。如果设置了 setfoucable(false),永远也获取不到焦点资格

多个edittext竖排处理:意在表单中想设置某一个如EditText获取焦点,光设置这个是不行的,需要将这个EditText前面的focusable都设置为false才行。

editext.clearfocus方法不好使

五、弹出键盘的问题

焦点与键盘没有必然的关系,与触摸事件有关系。

当触摸事件发生时,如果editext没有焦点,则会获取焦点,

当触摸事件发生时,会弹出键盘。

那么如何默认强制弹出软键盘呢?

使用不受限制, 即使editext没有焦点   androidmainfest中activity属性里边

android:windowSoftInputMode="stateVisible"进来就显示

adjustResize该Activity总是调整屏幕的大小以便留出软键盘的空间,这个也很常用。也是弹出软键盘的

各值的含义:

【A】stateUnspecified:软键盘的状态并没有指定,系统将选择一个合适的状态或依赖于主题的设置

【B】stateUnchanged:当这个activity出现时,软键盘将一直保持在上一个activity里的状态,无论是隐藏还是显示

【C】stateHidden:用户选择activity时,软键盘总是被隐藏

【D】stateAlwaysHidden:当该Activity主窗口获取焦点时,软键盘也总是被隐藏的

【E】stateVisible:软键盘通常是可见的,一进来就显示键盘

【F】stateAlwaysVisible:用户选择activity时,软键盘总是显示的状态

【G】adjustUnspecified:默认设置,通常由系统自行决定是隐藏还是显示

【H】adjustResize:该Activity总是调整屏幕的大小以便留出软键盘的空间

【I】adjustPan:当前窗口的内容将自动移动以便当前焦点从不被键盘覆盖和用户能总是看到输入内容的部分

"stateUnspecified":The state of the soft keyboard (whether it is hidden or visible) is not specified. The system will choose an appropriate state or rely on the setting in the theme. This is the default setting for the behavior of the soft keyboard. 软键盘的状态(隐藏或可见)没有被指定。系统将选择一个合适的状态或依赖于主题的设置。这个是软件盘行为的默认设置。

"stateUnchanged":The soft keyboard is kept in whatever state it was last in, whether visible or hidden, when the activity comes to the fore. 软键盘被保持上次的状态。

"stateHidden":The soft keyboard is hidden when the user chooses the activity — that is, when the user affirmatively navigates forward to the activity, rather than backs into it because of leaving another activity. 当用户选择该Activity时,软键盘被隐藏。

"stateAlwaysHidden":The soft keyboard is always hidden when the activity‘s main window has input focus. 软键盘总是被隐藏的。

"stateVisible":The soft keyboard is visible when that‘s normally appropriate (when the user is navigating forward to the activity‘s main window). 软键盘是可见的。

"stateAlwaysVisible":The soft keyboard is made visible when the user chooses the activity — that is, when the user affirmatively navigates forward to the activity, rather than backs into it because of leaving another activity. 当用户选择这个Activity时,软键盘是可见的。

"adjustUnspecified":It is unspecified whether the activity‘s main window resizes to make room for the soft keyboard, or whether the contents of the window pan to make the currentfocus visible on-screen. The system will automatically select one of these modes
depending on whether the content of the window has any layout views that can scroll their contents. If there is such a view, the window will be resized, on the assumption that scrolling can make all of the window‘s contents visible within a smaller area. This
is the default setting for the behavior of the main window. 它不被指定是否该Activity主窗口调整大小以便留出软键盘的空间,或是否窗口上的内容得到屏幕上当前的焦点是可见的。系统将自动选择这些模式中一种主要依赖于是否窗口的内容有任何布局视图能够滚动他们的内容。如果有这样的一个视图,这个窗口将调整大小,这样的假设可以使滚动窗口的内容在一个较小的区域中可见的。这个是主窗口默认的行为设置。也就是说,系统自动决定是采用平移模式还是压缩模式,决定因素在于内容是否可以滚动。

"adjustResize":(压缩模式)The activity‘s main window is always resized to make room for the soft keyboard on screen. 当软键盘弹出时,要对主窗口调整屏幕的大小以便留出软键盘的空间。

"adjustPan":(平移模式:当输入框不会被遮挡时,该模式没有对布局进行调整,然而当输入框将要被遮挡时,窗口就会进行平移。也就是说,该模式始终是保持输入框为可见。)The activity‘s main window is not resized to make room for the soft keyboard. Rather, the contents of the window are automatically panned so that the current focus is never
obscured by the keyboard and users can always see what they are typing. This is generally less desirable than resizing, because the user may need to close the soft keyboard to get at and interact with obscured parts of the window. 该Activity主窗口并不调整屏幕的大小以便留出软键盘的空间。相反,当前窗口的内容将自动移动以便当前焦点从不被键盘覆盖和用户能总是看到输入内容的部分。这个通常是不期望比调整大小,因为用户可能关闭软键盘以便获得与被覆盖内容的交互操作。。

3.侦听软键盘的显示隐藏

有时候,借助系统本身的机制来实现主窗口的调整并非我们想要的结果,我们可能希望在软键盘显示隐藏的时候,手动的对布局进行修改,以便使软键盘弹出时更加美观。这时就需要对软键盘的显示隐藏进行侦听。

我们可以借助软键盘显示和隐藏时,对主窗口进行了重新布局这个特性来进行侦听。如果我们设置的模式为压缩模式,那么我们可以对布局的onSizeChanged函数进行跟踪,如果为平移模式,那么该函数可能不会被调用。

如何默认不弹出软件键盘

方法一:

在AndroidMainfest.xml中选择哪个activity,设置windowSoftInputMode属性为adjustUnspecified|stateHidden

方法二:

强制隐藏Android输入法窗口

例如:EditText edit=(EditText)findViewById(R.id.edit);

InputMethodManager imm = (InputMethodManager)getSystemService(Context.INPUT_METHOD_SERVICE);

imm.hideSoftInputFromWindow(edit.getWindowToken(),0);

方法三EditText始终不弹出软件键盘(不太用,你始终不弹出来,你用它干嘛)

例:EditText edit=(EditText)findViewById(R.id.edit);

edit.setInputType(InputType.TYPE_NULL);

在应用键盘时,需要考虑这么几个问题:

【一】当有焦点产生时,软键盘是隐藏还是显示

【二】是否减少活动主窗口大小以便腾出空间放软键盘

键盘中的显示什么可以自己定义:android:imeOptions="actionDone"后将设置为Done点击是将关闭软盘

,send,search等。默认的软盘显示的action是“Next”,点击会到下一个输入框,如下:

六、焦点变化监听onWindowFocusChanged()    /**  * onWindowFocusChanged方法用于监听一个activity是否加载完毕,

Activity生命周期中,     * onStart, onResume, onCreate都不是真正visible的时间点,真正的visible时间点是onWindowFocusChanged()函数被执行

七、相关类的说明

例子:

setFocusable()   设置view接受焦点的资格

isFocusable()    view是否具有接受焦点的资格

setFocusInTouchMode()      对应在触摸模式下,设置是否有焦点来响应点触的资格

isFocusableInTouchMode()  对应在触摸模式下,view是否具有焦点的资格

requestFocus()

requestFocus(int direction)当用户在某个界面聚集焦点,参数为下面的4个

View.FOCUS_LEFT     Move focus to the left

View.FOCUS_UP       Move focus up

View.FOCUS_RIGHT    Move focus to the right

View.FOCUS_DOWN     Move focus down

requestFocusFromTouch()    触摸模式下

requestChildFocus (View child, View focused)   ------viewGroup

1 父元素调用此方法

2 child  将要获取焦点的子元素

3 focused 现在拥有焦点的子元素

isInTouchMode()    触摸模式

时间: 2024-11-11 03:04:26

焦点问题总结的相关文章

js最基础知识回顾2(函数传参,操作属性的第二种方式,提取行间事件,操作一组元素,this,焦点问题和鼠标按下抬起,选项卡)

一.函数传参     1.函数传参:参数就是占位符----函数里定不下来的东西 a. var a1=function(){ alert(123); }; function a(f){ // 相当于 f=a1 f(); }; a(a1); b.  function skip(skipPath){  //换肤 var oLink1 = document.getElementById('link1'); oLink1.href=skipPath; } c.   function setStyle(na

android的EditText重新获取焦点问题

在android开发过程中关于EditText在setFocusable(false);后,当需要再次获得焦点输入时设置setFocusable(true);后还是无法获得焦点的问题: 解决办法: 对EditText设置后就可以了! et.setFocusable(true); et.setFocusableInTouchMode(true); et.requestFocus(); et.findFocus(); android的EditText重新获取焦点问题

easyui------设置datagrid(&#39;getEditor&#39;)时焦点问题

代码: var dg = $(DataGrid.TableGridID); var row = { ID: "", UserName: "", Password: "", IsRemembered: "", CreateTime: "" }; dg.datagrid('insertRow', { index: 0, row: row }); var selectIndex = dg.datagrid('ge

ActivityGroup打开空文件夹焦点问题及返回键问题

ActivityGroup成功的解决了几个activity交替切换的问题,且比Tabhost具有更强的可拓展性. 在做一款多媒体文件浏览的软件时候,遇到了如下问题: 问题一:打开空文件夹时,由于焦点无处附着,当前activity的onPause(),默认activity的onResume(). 打开一个空文件夹,子activity的adater为空,此时子activity的焦点无处附着,运行完notifyDataSetChanged()方法之后就会走入onPause()方法,进而activity

Android基础入门教程——2.4.4 ListView的焦点问题

Android基础入门教程--2.4.4 ListView的焦点问题 标签(空格分隔): Android基础入门教程 本节引言: 如果你往ListView的Item中添加了Button,CheckBox,EditText等控件的话,你可能需要考虑 到一个问题:ListView的一个焦点问题!本节我们就来学习下解决这个问题的几个方法! 我们可以写个简答的listView,上面有一个Button,CheckBox,EditText,但是当我们点击发现, ListView的item点击不了,触发不了o

ListView的焦点问题

本节引言 如果你往ListView的Item中添加了Button,CheckBox,EditText等控件的话,你可能需要考虑 到一个问题:ListView的一个焦点问题!本节我们就来学习下解决这个问题的几个方法! 我们可以写个简答的listView,上面有一个Button,CheckBox,EditText,但是当我们点击发现, ListView的item点击不了,触发不了onItemClick的方法,也触发不了onItemLongClick方法, 这个就是ListView的一个焦点问题了!就

android 所有焦点问题--Focus

一. 主动获取焦点 setFocusable(true);    //  是设置能否获得焦点而已.. requestFocus();          //是让控件得到焦点 requestFocusInWindow()  //的作用应该是获取窗口的焦点 二.子类是否获取焦点 开发中很常见的一个问题,项目中的listview不仅仅是简单的文字,常常需要自己定义listview,自己的Adapter去继承BaseAdapter,在adapter中按照需求进行编写,问题就出现了,可能会发生点击每一个i

Android 设置系统的返回键 和软键盘获取焦点问题

很多朋友出现过这样的一个问题,当底部弹出评论框时,有几个问题,一个是软件盘弹出时怎么让焦点在输入框,关于这个问题,本人也是遇到过,解决了很久,有的是在布局设置或者代码里setFocusable(true),并没有用,又在代码或者代码里设置requestFocus(),依然没有用,其实这个解决办法是没有错的,但是为什么会没用呢,因为并没有及时是在软件盘弹出时设置,所以先提出隐藏和显示软件盘的方法 private void onFocusChange(boolean hasFocus) { fina

Android中涉及到的焦点问题,focusable,clickable,enabled

先摘抄下stackoverflow上一个启发了我的回答: try by Changing your code as: private OnClickListener saveButtonListener = new OnClickListener() { @Override public void onClick(View v) { Text1.clearFocus(); Text2.clearFocus(); saveButton.requestFocus(); //or any other

div/span等获取焦点问题(tabindex属性的简单理解)

1.先看问题 当我们要对一个div/span元素获取焦点的时候,直接对$("#div1").focus()是不能实现效果的,比如下图: 当点击输入框进行输入后,在点击区域弹出选择地段的时候,input输入框并没有失去焦点(或者说区域的div没有获得焦点),就出现了键盘显示在弹层的上面导致无法选择的bug 解决办法有两个: a:循环所有的input等可以获取焦点的元素,让他们失去焦点(blur); b:点击区域选择地段的时候让div获取焦点,从而解决input不失焦的问题: 在这里对于普