首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

Android笔记:软键盘弹出遮盖原来界面的布局控件

android:screenOrientation="portrait" android:label="@string/app_name" > 这样会让屏幕整体上移...windowSoftInputMode各值的含义: 【A】stateUnspecified:软键盘的状态并没有指定,系统将选择一个合适的状态或依赖于主题的设置   【B】stateUnchanged...:当这个activity出现时,软键盘将一直保持在上一个activity里的状态,无论是隐藏还是显示   【C】stateHidden:用户选择activity时,软键盘总是被隐藏   【D】stateAlwaysHidden...:当该Activity主窗口获取焦点时,软键盘也总是被隐藏的   【E】stateVisible:软键盘通常是可见的   【F】stateAlwaysVisible:用户选择activity时,软键盘总是显示的状态...  【G】adjustUnspecified:默认设置,通常由系统自行决定是隐藏还是显示   【H】adjustResize:该Activity总是调整屏幕的大小以便留出软键盘的空间   【I】adjustPan

1.1K20

自适应软键盘的Dialog以及监听软键盘弹起

Dialog的布局要适应软键盘的弹起2. 软键盘弹起和收下的时候都会有不同的引导,所以要在Dialog上监听软键盘的弹起。 需求的解决: 一:适应键盘的弹起。...我们知道,在Activity中如果要让布局不被软键盘遮挡,方法一般是在清单文件中配置windowSoftInputMode属性, windowSoftInputMode是Android1.5以后的一个新特性...,主要是对软键盘操作的,主要有以下属性: stateUnspecified:软键盘的状态并没有指定,系统将选择一个合适的状态或依赖于主题的设置 stateUnchanged:当这个activity出现时...二,基于Dialog监听软键盘的弹起和收下: 其实看完第一个需求,我们可能已经猜想到,软键盘也是基于当前窗口的,它的弹起和收下肯定会引起当前窗口布局的属性发生变化,所以解决思路就有了:监听当前布局的变化...我这里是比较布局坐标中的下坐标的,因为如果键盘弹起的话,布局的下坐标肯定会变小。

3.6K30
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    android基础

    布局 基本布局 FrameLayout 线性布局 LinearLayout 相对布局 RelativeLayout 绝对布局 AbsduteLayout 表格布局 TableLayout 标签布局 TabLayout...如果targetSdkVersion设置为16或更低的设置为false,RTL的API将被忽略或没有影响您的应用程序将具有相同的行为无论对用户现场的选择相关的布局方向(你的布局会从左至右)。...这个属性能影响两件事情: 【一】当有焦点产生时,软键盘是隐藏还是显示 【二】是否减少活动主窗口大小以便腾出空间放软键盘 它的设置必须是下面列表中的一个值,或一个”state…”值加一个”adjust…”...,系统将选择一个合适的状态或依赖于主题的设置 【B】stateUnchanged:当这个activity出现时,软键盘将一直保持在上一个activity里的状态,无论是隐藏还是显示 【C】stateHidden...:用户选择activity时,软键盘总是被隐藏 【D】stateAlwaysHidden:当该Activity主窗口获取焦点时,软键盘也总是被隐藏的 【E】stateVisible:软键盘通常是可见的

    78020

    Android获取软键盘的高度、键盘的打开与关闭、监听键盘处于打开还是关闭状态

    最近在项目中,需要获取到软键盘的高度,再将底部的布局上移键盘的高度,话不多说,直接上代码: 获取软键盘高度 //一个静态变量存储高度 public static int keyboardHeight...addOnGlobalLayoutListener(onGlobalLayoutListener); } 键盘的打开与关闭操作: public class KeybordS { /** * 打开软键盘...InputMethodManager.SHOW_FORCED, InputMethodManager.HIDE_IMPLICIT_ONLY); } /** * 关闭软键盘...Context.INPUT_METHOD_SERVICE); imm.hideSoftInputFromWindow(mEditText.getWindowToken(), 0); } /** * 关闭软键盘...inputManager.hideSoftInputFromWindow(activity.getCurrentFocus().getWindowToken(), 0); } } /** * 判断当前软键盘是否打开

    7.8K10

    Android 软键盘的那些事

    ,系统将选择一个合适的状态或依赖于主题的设置 【B】stateUnchanged:当这个activity出现时,软键盘将一直保持在上一个activity里的状态,无论是隐藏还是显示 【C】stateHidden...:用户选择activity时,软键盘总是被隐藏 【D】stateAlwaysHidden:当该Activity主窗口获取焦点时,软键盘也总是被隐藏的 【E】stateVisible:软键盘通常是可见的...) android:windowSoftInputMode 活动的主窗口如何与包含屏幕上的软键盘窗**互。...2> 活动的主窗口调整——是否减少活动主窗口大小以便腾出空间放软键盘或是否当活动窗口的部分被软键盘覆盖时它的内容的当前焦点是可见的。...系统将自动选择这些模式中一种主要依赖于是否窗口的内容有任何布局视图能够滚动他们的内容。如果有这样的一个视图,这个窗口将调整大小,这样的假设可以使滚动窗口的内容在一个较小的区域中可见的。

    2K10

    Android开发笔记(三十六)展示类控件

    在XML布局文件中实现时,可设置如下属性: gravity : 指定文本的对齐方式,一般取值“left|bottom”,表示靠左对齐且靠下对齐。 lines : 指定文本的行数。...所以要实现聊天室效果必须同时修改xml布局文件与代码。 2、在文字周围放置图片。通过在线性布局内部放置ImageView控件也能实现,但显然不如在TextView控件内部加入图片来得方便。...在XML布局文件中实现时,可设置如下属性: drawableTop : 指定文本上方的图形。 drawableBottom : 指定文本下方的图形。...EditText还有一个需要特殊处理的地方,就是自动关闭软键盘。一般我们希望点击其它控件时,原输入框的软键盘就要自动消失,可惜Android不是这样处理。...下面是自动关闭软键盘的两种方法: 1、调用toggleSoftInput方法,该方法会关闭所有控件弹出的软键盘; InputMethodManager imm = (InputMethodManager

    1.5K30

    Android开发笔记(一百四十八)自定义输入法软键盘

    然而系统软键盘即使切换到123数字模式,依旧显示包括标点符号在内的冗余按键。 2、系统软键盘固定在屏幕下方弹出,无法做为控件嵌入到页面布局中,更无法指定软键盘的显示位置。...软键盘采取的是后一种方式,只不过它的布局文件不是放在res/layout目录,而是保存在res/xml目录。...2、自定义控件的主要工作是书写自定义的控件类,自定义软键盘也不例外,有了自定义的控件类,才能处理十个数字键的按键动作,才能把软键盘做为普通的控件嵌入到其它布局文件中。... 然后是编写自定义软键盘的控件代码了,这里的关键是用自定义的键盘布局替换掉系统默认的键盘布局...EditText对象,即当软键盘发生按键动作时,要把按键结果显示在哪个EditText上。

    2.7K30

    Android富文本开发

    这些动画效果在LayoutTransition中,由以下四个关键字做出了相关声明: APPEARING:元素在容器中显现时需要动画显示。...="true" (效果:软键盘不弹出,光标不显示,其他输入框也不获取焦点,ps非直接父布局没有效果) 在父布局最顶部添加一个高度为0的EditText,抢了焦点但不展示; 软键盘遮挡界面的问题 当界面中有输入框...adjustResize-调整模式:当软键盘显示的时候,当前界面会自动重绘,会被压缩,软键盘消失之后,界面恢复正常(正常布局,非scrollView父布局);当父布局是scrollView的时候,软键盘弹出...,会将布局顶起(保证输入框不被遮挡),不压缩,而且可以软键盘不消失的情况下,手动滑出被遮挡的布局; adjustPan-默认模式:软键盘弹出,软键盘会遮挡屏幕下半部分布局,当输入框在屏幕下方布局,软键盘弹起...,会自动将当前布局顶起,保证,软键盘不遮挡当前输入框(正常布局,非scrollView父布局)。

    8.5K20

    Android 底部按钮被软键盘顶起问题解决

    如果界面中有可滑动控件,显示效果跟 adjustUnspecified 显示效果一样;如果界面中没有可滑动控件,软键盘可能会盖住一些控件(布局的位置不会发生变化,可能获取了焦点的控件被软键盘盖住)。...一般来说,我们的布局分为两种 底部按钮被滚动布局包裹 底部按钮不被滚动布局包裹 第一种布局是不会出现软键盘把底部按钮顶起的情况,首先软键盘的打开实际上是一个 Dialog,而我们在配置文件内的 adjustResize...属性是在页面的根布局 decorView 的子 view 也就是一个线性布局内通过设置 paddingBottom = 软键盘高度,这样其实相当于把整个滚动布局的高度减少了,所以底部的按钮也只是变为需要滚动才能看到...第二种情况通常为一个继续按钮始终处于页面的底部,中间的内容可以滚动,当根布局的内边距等于软键盘高度时,底部按钮就看起来像是被顶起。...从大的方向来说可以通过修改 windowSoftInputMode 来设置布局对软键盘的处理方式,当然也可以通过监听软键盘,这种修改的细粒度更小。

    2.2K20

    iOS微信浏览器input聚焦导致页面上移,不能恢复的解决方法

    H5页面在iOS系统微信浏览器中,input focus 聚焦时页面会被上推,导致页面整体上移。...最后发现是因为 iOS 中 input 聚焦时会导致页面上移,失焦后页面不能恢复,但是 input 会恢复之前的位置(或者说下移)。...+Mac OS X/); if (isIOS) {   document.body.addEventListener('focusin', () => {  //软键盘弹起事件     flag = true...;     clearTimeout(toScroll);   })   document.body.addEventListener('focusout', () => { //软键盘关闭事件     ...    } else {       return     }   }) } else {   return } 声明:本文由w3h5原创,转载请注明出处:《iOS微信浏览器input聚焦导致页面上移,

    3.3K10

    手机软键盘弹起导致页面变形的一种解决方案

    最近用 uniapp(一种第三方 app 开发框架) 开发 app,其中一个页面有十几个 input 输入框,在点击 input 输入时,软键盘弹起,导致页面往上顶,底部的按钮也全部弹到页面上面去了,布局全被打乱...当 input 获取焦点时,软键盘弹出,页面高度被挤压,此时页面高度 = 屏幕高度 - 软键盘高度。所以,页面高度缩小,元素都挤压在一起,布局被打乱。...一种可行的解决方案:给页面设置一个最小高度,即一个能让所有元素按原来布局排列的高度。...举例: 我开发的 APP 运行在 ipad上,横屏显示时,高度为 768px ,我可以把 768px 当做页面的最小高度。...但至少我们要的页面布局不变形已经实现了。等输入完,软键盘收起时,页面恢复原状。 ipad 的问题解决了,要是 APP 运行在其他手机端上呢?此时,CSS3 @media 属性就排上用场了。

    2.6K40

    响应视窗属性动画 | 让您的软键盘动起来 (二)

    为了展示可以实现的效果,您可以查看下面这个来自同一个应用的示例,左边的是运行在 Android 10 上,而右边的是运行在 Android 11 上 (动画效果是实际速度的 20%): ?...如上动图所示: 在 Android 10 以及以前版本的设备上,当用户点击文字输入框来输入回复,软键盘会带着动画效果移动到预期的位置,但是应用在两个状态间的动画很突兀。...这是一个您在设备上已经看过很久的效果,降慢速度到实际速度的 20% 使得它更为明显。 您可以在右边看到相同的场景运行在 Android 11 上的效果。...在软键盘的这个例子中,这个调用会发生在软键盘在屏幕 // 上滑动的时候。...由于系统保证了任何由视窗属性变更导致的重新布局都会在 onStart() 的同一帧被调用,所以用户此时不会看到闪动。 ?

    74320

    移动端那些戳中你痛点的软键盘问题及解决方法

    这个参考了朱雷大佬提供的这个文章:WebView上软键盘的兼容方案[1] IOS 软键盘弹起表现 在 IOS 上,输入框(input、textarea 或 富文本)获取焦点,键盘弹起,页面(webview...Android 软键盘弹起表现 同样,在 Android 上,输入框获取焦点,键盘弹起,但是页面(webview)高度会发生改变,一般来说,高度为可视区高度(原高度减去软键盘高度),除了因为页面内容被撑开可以产生滚动...但是,触发键盘上的收起按钮键盘时,输入框并不会失去焦点,同样软键盘收起。 ? ? 2、为什么fixed会失效 既然ios键盘弹起时,页面会上移,那么为什么fixed会失效呢。...同样参考这篇文章:WebView上软键盘的兼容方案[3] 综合上面键盘弹起和收起在 IOS 和 Android 上的不同表现,我们可以分开进行如下处理来监听软键盘的弹起和收起: Ios 在 IOS 上,...在 Android 上,监听 webview 高度会变化,高度变小获知软键盘弹起,否则软键盘收起。 // IOS 键盘弹起:当输入框被聚焦时IOS键盘会被弹起 inputRef?.

    8.9K30

    iOS学习——tableview中带编辑功能的cell键盘弹出遮挡和收起问题解决

    首先,有一个很简单的解决方案,就是将我们的控制器换成UITableViewController或其子类,UITableViewController中的cell当有键盘弹出的时候表单整体会自动进行上移...♀️,我们的项目汇总因为用到了MBProgressHUD框架,所以只能是用UIViewController上布局一个UITableView来实现,这样我们再self.view上布局MBProgressHUD...2.2 自定义包含UITextField的UITableViewCell   首先,我们在点击编辑区域的时候,获取到当前编辑区域相对屏幕的位置,这样方便我们判断整个tableview是否需要上移以及需要上移多少比较合适...,我们需要知道当前编辑的cell相对屏幕的位置,然后才能判断是否需要上移tableview以及上移多少。...if (offSet > 0.01) { WEAKSELF //有遮挡时,tableview需要的偏移量应该是在原先的基础上再往上上移的,这里我们默认增加10个单位的空白

    3.9K80

    实现边到边的体验 | 让您的软键盘动起来 (一)

    Android 11 中的新功能之一是可以让应用在对于屏幕上的软键盘打开和关闭的过程创建无缝过渡的动画效果,这一功能源自 Android 11 中对 WindowInsets API 的大量改进。...如果我们回想 去年的介绍,实现边到边可以分为三步: 改变系统栏的颜色 设置全屏布局 处理视觉冲突 我们会跳过第一步,因为从去年至今这个部分没有改动。...#2: 设置全屏布局 在以往的第二步中,应用需要使用 systemUiVisibility API 以及一些参数来设置全屏布局: view.systemUiVisibility = // 通知系统...,视窗希望在极端的情况下该如何布局内容。...既然我们正在回答 StackOverflow 上的问题,来看一下这个 11 年前关于如何关闭软键盘的问题。

    35720

    AndroidMainifest标签说明2——<activity>

    除了根Activity,其它Activity都会被清除出栈,可是假设在根Activity中设置了此属性之后。用户再次启动应用时,仍然可以看到上一次操作的界面。...(这通常不应该发生) “screenLayout” 屏幕布局改变了——这可能是因为不同的显示被激活。...“reversePortrait” 肖象方向相反的方向从正常的肖像 “sensorLandscape” 横向,可是能够正常或反向景观基础设备上的传感器。...“stateUnchanged” 软键盘上一次保存在不论什么状态,是否可见或隐藏,当活动走到前台。 “stateHidden” 软键盘是隐藏的,当用户选择activity时。...“adjustResize” 活动的主窗体总是会去调整大小使软键盘在窗体中 “adjustPan” 活动的主窗体不是软键盘调整大小以腾出空间。

    1.5K00

    Android爬坑之旅:软键盘挡住输入框问题的终极解决方案

    adjustPan是把整个界面向上平移,使输入框露出,不会改变界面的布局; adjustResize则是重新计算弹出软键盘之后的界面大小,相当于是用更少的界面区域去显示内容,输入框一般自然也就在内了。...↑↑↑ OK,这只是入门,基本上地球上所有的Android工程师都能搞定。 别急,看下面~ 加上WebView试试看?坑来了…… 上面的入门篇中,软键盘是由原生的EditText触发弹出的。...这里所注册的addOnGlobalLayoutListener,就是会在当前的View树的全局布局(GlobalLayout)发生变化、或者其中的View可视状态有变化时,进行通知回调。...(实际上,这也常常被用作为获取标题栏高度的方法) 屏幕高度-rect.bottom,是软键盘的高度。...,是目前在视觉效果上能看到的界面高度。

    4.9K20

    【H5】344- 微信 H5 页面兼容性解决方案

    MDN上是这样定义的: -webkit-overflow-scrolling 属性控制元素在移动设备上是否使用滚动回弹效果. auto: 使用普通滚动, 当手指从触摸屏上移开,滚动会立即停止。...3、ios键盘唤起,键盘收起以后页面不归位 问题详情描述: 输入内容,软键盘弹出,页面内容整体上移,但是键盘收起,页面内容不下滑 出现原因分析: 固定定位的元素 在元素内 input 框聚焦的时候...弹出的软键盘占位 失去焦点的时候软键盘消失 但是还是占位的 导致input框不能再次输入 在失去焦点的时候给一个事件 解决办法: <div class...}, 200) } } 拓展知识: position: fixed的元素在ios里,收起键盘的时候会被顶上去,特别是第三方键盘 4、安卓弹出的键盘遮盖文本框 问题详情描述: 安卓微信H5弹出软键盘后挡住...【该方法未验证】 题外话: 如果能用小程序写的页面,尽量上小程序吧,H5开发在微信开发者工具里看页面效果可能看不出问题,因为不能唤起软键盘。

    2.7K30
    领券