热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

优化直播应用底部聊天框弹出机制,确保布局稳定兼容虚拟按键设备

为了优化直播应用底部聊天框的弹出机制,确保在不同设备上的布局稳定性和兼容性,特别是在配备虚拟按键的设备上,我们对用户交互流程进行了调整。首次打开应用时,需先点击首个输入框以准确获取键盘高度,避免直接点击第二个输入框导致的整体布局挤压问题。此优化通过调整`activity_main.xml`布局文件实现,确保了更好的用户体验和界面适配。
图片1图片2图片1图片2

效果图,如上

注意打开应用后,要点击第一个输入框,这是因为先要获取一次键盘的高度,不然首先点击第二个输入框,会出现整体布局挤压的现象。

布局文件

activity_main.xml

"1.0" encoding="utf-8"?>
"http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:layout_hljs-string">"match_parent"
android:layout_hljs-string">"match_parent"
android:background="@drawable/splash"
tools:cOntext="org.dync.softkeyboarddemo.MainActivity">

android:id="@+id/edt"
android:layout_hljs-string">"wrap_content"
android:layout_hljs-string">"wrap_content"
android:layout_alignParentLeft="true"
android:layout_alignParentStart="true"
android:hint="获取键盘高度"/>
android:layout_hljs-string">"wrap_content"
android:layout_hljs-string">"wrap_content"
android:text="键盘高度"
android:id="@+id/text"
android:layout_below="@+id/edt"
android:layout_alignParentLeft="true"
android:layout_alignParentStart="true" />

android:id="@+id/editText"
android:layout_hljs-string">"match_parent"
android:layout_hljs-string">"wrap_content"
android:layout_alignParentBottom="true"
android:layout_alignParentLeft="true"
android:layout_alignParentStart="true" />



在Activity中你只需编写以下代码就可实现底部EditText随键盘移动。
MainActivity

SoftKeyboardUtil.observeSoftKeyboard(activity, new SoftKeyboardUtil.OnSoftKeyboardChangeListener() {
@Override
public void onSoftKeyBoardChange(int softKeybardHeight, boolean isShow) {
mSoftKeybardHeight = softKeybardHeight;
isOpen = isShow;
if (isShow) {
onShowKeyboard(softKeybardHeight);
if (isTouch) {//点击输入框则不移动控件
editText.animate().translationYBy(-softKeybardHeight).setDuration(duration).start();
}
Log.e("TAG", "isShow--平移高度:" + -mSoftKeybardHeight);
} else {
onHideKeyboard(softKeybardHeight);
editText.animate().translationYBy(softKeybardHeight).setDuration(duration).start();
Log.e("TAG", "isHide--平移高度:" + mSoftKeybardHeight);
isTouch = true;//这里一定要设置,不然点击输入框,控件只会在第一次能移动,之后不会移动了
}
}
}
});

editText.setOnTouchListener(new View.OnTouchListener() {

@Override
public boolean onTouch(View v, MotionEvent event) {
Log.e("TAG", "--onTouch--");
if (!isOpen) {//键盘没有打开
if (isTouch) {//这里是因为onTouch()方法会不止一次调用,所以用boolean值来使得控件只移动一次
//这里设为false目的是防止这里延时弹出键盘会触发onSoftKeyBoardChange()会再一次调用移动控件的方法
isTouch = false;
//先移动到键盘弹出的高度再手动弹出键盘,这样就不会出现挤压布局的效果
editText.animate().translationYBy(-mSoftKeybardHeight).setDuration(duration).start();
Log.e("TAG", "平移高度:" + -mSoftKeybardHeight);
new Handler().postDelayed(new Runnable() {
public void run() {
SoftKeyboardUtil.showKeyboard(activity, editText);
}
}, duration);
}
}
return false;//这里不能返回true,不然焦点不会聚焦到该控件
}
});

...

@Override
protected void onDestroy() {
super.onDestroy();
SoftKeyboardUtil.removeGlobalOnLayoutListener(this);
}

代码详情请到github上预览。

转载请注明出处,谢谢!


推荐阅读
  • Redis 教程01 —— 如何安装 Redis
    本文介绍了 Redis,这是一个由 Salvatore Sanfilippo 开发的键值存储系统。Redis 是一款开源且高性能的数据库,支持多种数据结构存储,并提供了丰富的功能和特性。 ... [详细]
  • 本文深入探讨了Java注解的基本概念及其在现代Java开发中的应用。文章不仅介绍了如何创建和使用自定义注解,还详细讲解了如何利用反射机制解析注解,以及Java内建注解的使用场景。 ... [详细]
  • 微信小程序配置详解:pages、window、tabBar与调试模式
    本文详细介绍了如何在微信小程序中配置pages、window、tabBar以及启用调试模式,帮助开发者更好地理解和应用这些配置选项。 ... [详细]
  • 本文将详细介绍如何使用ViewPager实现多页面滑动切换,并探讨如何去掉其默认的左右切换动画效果。ViewPager是Android开发中常用的组件之一,用于实现屏幕间的内容切换。 ... [详细]
  • 本文介绍了NHibernate中通过定义接口和实现类来管理会话工厂的方法,包括接口的优势、模型文件夹的结构以及具体的代码示例。 ... [详细]
  • 本文通过一个具体的用户管理项目,详细介绍如何使用Spring MVC框架进行开发。从用户实体类的设计到控制器的实现,再到视图层的展示,全面解析Spring MVC的核心功能与实现细节。 ... [详细]
  • [TOC]Process的几个用法和守护进程一、Process的join用法话不多说,直接上代码二、Process的pid和ppid用法需要先导入os模块站在当前进程的角度:os. ... [详细]
  • 本文深入探讨了企业级开发框架NHibernate和Spring.NET的关键特性之一——面向方面编程(AOP)。文章不仅介绍了AOP的基本概念及其如何增强面向对象编程(OOP),还详细说明了Spring.NET中AOP的具体应用,包括事务管理和自定义方面的实现。 ... [详细]
  • Python作为一种广泛使用的高级编程语言,以其简洁的语法、强大的功能和丰富的库支持著称。本文将详细介绍Python的主要特点及其在现代软件开发中的应用。 ... [详细]
  • 今天我在操作Git时遇到了一个问题,即我的仓库进入了分离的HEAD状态,这与之前讨论过的‘即使本地有更改,git push仍显示所有内容最新’的问题类似。 ... [详细]
  • 手把手教你构建简易JSON解析器
    本文将带你深入了解JSON解析器的构建过程,通过实践掌握JSON解析的基本原理。适合所有对数据解析感兴趣的开发者。 ... [详细]
  • 本文详细介绍了如何手动编写兼容IE的Ajax函数,以及探讨了跨域请求的实现方法和原理,包括JSONP和服务器端设置HTTP头部等技术。 ... [详细]
  • 使用 NDB 提升 Node.js 应用调试体验
    本文介绍了由 Google Chrome 实验室推出的新一代 Node.js 调试工具 NDB,旨在为开发者提供更加高效和便捷的调试解决方案。 ... [详细]
  • BME框架使用中的典型问题解析
    本文主要探讨了BME框架在实际应用中遇到的一些常见问题,包括查询条件为空、动态参数处理及分页查询等场景的解决方案。 ... [详细]
  • 如何在UIWebView中加载本地图片
    本文详细介绍了如何在UIWebView中加载本地图片的方法,这对于需要在应用内展示静态页面和富文本内容的场景非常有用。 ... [详细]
author-avatar
书友48169582
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有