BottomSheetDialog 使用详解,设置圆角、固定高度,网易的朋友给我这份339页的Android面经

这里只是一个展示效果,实际上使用场景可能会复杂一些,还要做一些操作等等,所以,也可以自定义dialog继承自BottomSheetDialog,然后处理自己的业务逻辑。

比如:

class MyDialog(context: Context) : BottomSheetDialog(context) {

override fun onCreate(savedInstanceState: Bundle?) {

super.onCreate(savedInstanceState)

}

}

4.BottomSheetDialogFragment

======================================================================================

在这里插入图片描述

效果跟BottomSheetDialog差不多,代码跟DialogFragment差不多。

代码

class MyBottomSheetDialog : BottomSheetDialogFragment() {

override fun onCreateDialog(savedInstanceState: Bundle?): Dialog {

val dialog = super.onCreateDialog(savedInstanceState)

val view = LayoutInflater.from(context).inflate(R.layout.dialog_my_bottom_sheet, null)

dialog.setContentView(view)

initView(view)

return dialog

}

private fun initView(rootView: View) {

//do something

rootView.tv_cancel.setOnClickListener { dismiss() }

}

}

在创建dialog的时候引入布局,然后setContentView即可。

调用:

MyBottomSheetDialog().show(supportFragmentManager, “MyBottomSheetDialog”)

  • FragmentManager

  • tag

但是在实际开发中,我们的需求可能并不能满足于此,比如上部分圆角效果指定高度

5.圆角效果

=================================================================

  • 先设置原有背景透明

style.xml

  • onCreate中设置style

override fun onCreate(savedInstanceState: Bundle?) {

super.onCreate(savedInstanceState)

setStyle(STYLE_NORMAL, R.style.BottomSheetDialog)

}

  • 设置我们自己的style

根布局的view上设置background

android:background=“@drawable/shape_sheet_dialog_bg”

shape_sheet_dialog_bg

<?xml version="1.0" encoding="utf-8"?>

<corners

android:topLeftRadius=“15dp”

android:topRightRadius=“15dp” />

6.去掉背景阴影

===================================================================

在这里插入图片描述

可以看到是没有阴影蒙版的,还是style,设置backgroundDimEnabledfalse即可

7.设置固定高度

===================================================================

在这里插入图片描述

可以看到这个弹窗一开始并不是完全展开的,但是可以继续拉出来。

代码

override fun onStart() {

super.onStart()

//拿到系统的 bottom_sheet

val view: FrameLayout = dialog?.findViewById(R.id.design_bottom_sheet)!!

//获取behavior

val behavior = BottomSheetBehavior.from(view)

//设置弹出高度

behavior.peekHeight = 350

}

有一个peekHeight属性可以设置高度,但是这个api并没有开放给我们,不过也有解决办法

我们可以查看bottomSheetDialog.setContentView的源码

@Override

public void setContentView(@LayoutRes int layoutResId) {

super.setContentView(wrapInBottomSheet(layoutResId, null, null));

}

这里调用了wrapInBottomSheet,继续探索

private View wrapInBottomSheet(int layoutResId, @Nullable View view, @Nullable ViewGroup.LayoutParams params) {

ensureContainerAndBehavior();

return container;

}

多余的可以不用看,直接探索ensureContainerAndBehavior();方法

/** Creates the container layout which must exist to find the behavior */

private FrameLayout ensureContainerAndBehavior() {

if (container == null) {

container =

(FrameLayout) View.inflate(getContext(), R.layout.design_bottom_sheet_dialog, null);

FrameLayout bottomSheet = (FrameLayout) container.findViewById(R.id.design_bottom_sheet);

behavior = BottomSheetBehavior.from(bottomSheet);

behavior.addBottomSheetCallback(bottomSheetCallback);

behavior.setHideable(cancelable);

}

return container;

}

到这里,我们就可以看到源码是怎么获取behavior的了,获取到behavior之后就可以调用peekHeight设置高度了。

8.设置默认全屏显示

=====================================================================

既然有了上面的方法,是不是有思路了,那有人说了,我把高度设置全屏不就完事了吗

事实上还真不行,BottomSheetDialogFragment只会显示实际高度,即布局有效高度,即使根布局高度match_parent也不行。

既然我们自己的view不行,那就从BottomSheetDialogFragment本身下手,还记得上面我们通过dialog?.findViewById(R.id.design_bottom_sheet)!!拿到的view吗,我们试一下设置这个view的高度行不行

view.layoutParams.height = ViewGroup.LayoutParams.MATCH_PARENT

看看效果

在这里插入图片描述

首先是像默认效果一样,当内容大于等于全屏的时候,会先到达一个高度,即上面效果的高度,然后继续向上滑的话,可以铺满全屏。

虽然不是预想的效果,但是既然还可以向上滑动至全屏,说明我们设置的高度是有效的,只是没有一次性展开而已,还记得前面提到的状态state吗,设置一下试试

behavior.state = BottomSheetBehavior.STATE_EXPANDED

看看效果

在这里插入图片描述

可以了,这下是直接就全屏了,但是向下拉的时候发现,并没有一次性收起,而是先停在了全屏时显示的默认位置,我们再设置高度为全屏试试

behavior.peekHeight = 3000

自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数Android工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则几千的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年Android移动开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。
img
img
img
img
img
img
img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Android开发知识点,真正体系化!

由于文件比较大,这里只是将部分目录大纲截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且后续会持续更新

如果你觉得这些内容对你有帮助,可以添加V获取:vip204888 (备注Android)
img

尾声

开发是需要一定的基础的,我是08年开始进入Android这行的,在这期间经历了Android的鼎盛时期,和所谓的Android”凉了“。中间当然也有着,不可说的心酸,看着身边朋友,同事一个个转前端,换行业,其实当时我的心也有过犹豫,但是我还是坚持下来了,这次的疫情就是一个好的机会,大浪淘沙,优胜劣汰。再等等,说不定下一个黄金浪潮就被你等到了。

  • 330页 PDF Android核心笔记

  • 几十套阿里 、字节跳动、腾讯、华为、美团等公司2020年的面试题

  • PDF和思维脑图,包含知识脉络 + 诸多细节

  • Android进阶系统学习视频

oid的鼎盛时期,和所谓的Android”凉了“。中间当然也有着,不可说的心酸,看着身边朋友,同事一个个转前端,换行业,其实当时我的心也有过犹豫,但是我还是坚持下来了,这次的疫情就是一个好的机会,大浪淘沙,优胜劣汰。再等等,说不定下一个黄金浪潮就被你等到了。

  • 330页 PDF Android核心笔记

[外链图片转存中…(img-SKtjb2QF-1711744047803)]

  • 几十套阿里 、字节跳动、腾讯、华为、美团等公司2020年的面试题

[外链图片转存中…(img-nz9FGryP-1711744047803)]

[外链图片转存中…(img-ZuB6yTf4-1711744047803)]

  • PDF和思维脑图,包含知识脉络 + 诸多细节

[外链图片转存中…(img-9QKmB8yM-1711744047804)]

  • Android进阶系统学习视频

[外链图片转存中…(img-JdxQJsLR-1711744047804)]

本文已被CODING开源项目:《Android学习笔记总结+移动架构视频+大厂面试真题+项目实战源码》收录

  • 24
    点赞
  • 19
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值