• linkedu视频
  • 平面设计
  • 电脑入门
  • 操作系统
  • 办公应用
  • 电脑硬件
  • 动画设计
  • 3D设计
  • 网页设计
  • CAD设计
  • 影音处理
  • 数据库
  • 程序设计
  • 认证考试
  • 信息管理
  • 信息安全
菜单
linkedu.com
  • 网页制作
  • 数据库
  • 程序设计
  • 操作系统
  • CMS教程
  • 游戏攻略
  • 脚本语言
  • 平面设计
  • 软件教程
  • 网络安全
  • 电脑知识
  • 服务器
  • 视频教程
  • JavaScript
  • ASP.NET
  • PHP
  • 正则表达式
  • AJAX
  • JSP
  • ASP
  • Flex
  • XML
  • 编程技巧
  • Android
  • swift
  • C#教程
  • vb
  • vb.net
  • C语言
  • Java
  • Delphi
  • 易语言
  • vc/mfc
  • 嵌入式开发
  • 游戏开发
  • ios
  • 编程问答
  • 汇编语言
  • 微信小程序
  • 数据结构
  • OpenGL
  • 架构设计
  • qt
  • 微信公众号
您的位置:首页 > 程序设计 >Android > Bottom Sheet

Bottom Sheet

作者:网友 字体:[增加 减小] 来源:互联网 时间:2017-05-26

网友通过本文主要向大家介绍了bottomsheetdialog,bottomsheetbehavior,bottomsheetlayout,android bottomsheet,bottomsheetfragment等相关知识,希望对您有所帮助,也希望大家支持linkedu.com www.linkedu.com

Bottom Sheet


上周android推出了Android Support Library 23.2版本,提供了一些新的API支持和对现有库增加新特性。

先来看看Bottom Sheet这个控件。

该控件一般用于底部划出表单,Material Design 设计官网上就有这种设计。

图片名称


来看怎么用:

通过为CoordinatorLayout 的一个子view添加BottomSheetBehavior 表现行为即可。



    
        
    
    

layout_bottom_sheet.xml 里面定义的是sheet的布局,里面定义成什么就看你自己想怎么写了。

需要注意的就是,sheet的布局必须是CoordinatorLayout 的一个子view。

public static  BottomSheetBehavior from(V view) {
        ViewGroup.LayoutParams params = view.getLayoutParams();
        if (!(params instanceof CoordinatorLayout.LayoutParams)) {
            throw new IllegalArgumentException("The view is not a child of CoordinatorLayout");
        }
        CoordinatorLayout.Behavior behavior = ((CoordinatorLayout.LayoutParams) params)
                .getBehavior();
        if (!(behavior instanceof BottomSheetBehavior)) {
            throw new IllegalArgumentException(
                    "The view is not associated with BottomSheetBehavior");
        }
        return (BottomSheetBehavior) behavior;
    }

通过上面的代码可以看出,不是子view会出现IllegalArgumentException.


Bottom Sheet 一共有五个状态回调:

STATE_COLLAPSED
折叠状态。可通过app:behavior_peekHeight来设置默认显示的高度。

STATE_SETTING
拖拽松开之后到达终点位置(collapsed or expanded)前的状态。

STATE_EXPANDED
完全展开的状态。

STATE_HIDDEN
隐藏状态。默认是false,可通过app:behavior_hideable属性设置。

STATE_DRAGGING
被拖拽状态

View bottomSheet = findViewById(R.id.bottom_sheet);
        BottomSheetBehavior behavior = BottomSheetBehavior.from(bottomSheet);
        behavior.setBottomSheetCallback(new BottomSheetBehavior.BottomSheetCallback() {
            @Override
            public void onStateChanged(View bottomSheet, int newState) {
                String state = "null";
                switch (newState) {
                    case 1:
                        state = "STATE_DRAGGING";
                        break;
                    case 2:
                        state = "STATE_SETTLING";
                        break;
                    case 3:
                        state = "STATE_EXPANDED";
                        break;
                    case 4:
                        state = "STATE_COLLAPSED";
                        break;
                    case 5:
                        state = "STATE_HIDDEN";
                        break;
                }
                Log.d("MainActivity", "newState:" + state);
            }
            @Override
            public void onSlide(View bottomSheet, float slideOffset) {
//                Log.d("MainActivity", "slideOffset:" + slideOffset);
            }
        });

注意:
如果Bottom Sheet中有需要滑动的视图,必须支持嵌套滑动才行。比如:NestedScrollView、RecyclerView或者API 21 + 上的ListView、ScrollView。


Support Library 23.2中还提供了BottomSheetDialog和BottomSheetDialogFragment。

用法与普通的dialog差不多。

Button dialogBtn = (Button) findViewById(R.id.bottom_sheet_dialog_btn);
        dialogBtn.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {
                BottomSheetDialog dialog = new BottomSheetDialog(BottomSheetDemo.this);
                dialog.setContentView(R.layout.bottom_sheet_dialog_layout);
                dialog.show();
            }
        });

bottom_sheet_dialog_layout.xml




    

        

效果图:

图片名称


Bottom Sheet介绍完毕。

分享到:QQ空间新浪微博腾讯微博微信百度贴吧QQ好友复制网址打印

您可能想查找下面的文章:

  • Android Bottom Sheet详解
  • Bottom Sheet

相关文章

  • 2017-05-26pgpool的健康检查和failover代码
  • 2017-05-26android View绘制源码分析
  • 2017-05-26Android开发之初识MVP模式
  • 2017-05-26Android启动篇 — init原理(二),androidinit
  • 2017-05-26Android 友盟分享详细集成过程及所遇问题解决,android
  • 2017-05-26Android 反编译和混淆,android反编译混淆
  • 2017-05-26Android开发学习-view,android开发-view
  • 2017-05-26Amazon Alexa登录授权(Android),amazonandroid
  • 2017-05-26Bottom Sheet
  • 2017-05-26Android搜索功能的案例,本地保存搜索历史记录

文章分类

  • JavaScript
  • ASP.NET
  • PHP
  • 正则表达式
  • AJAX
  • JSP
  • ASP
  • Flex
  • XML
  • 编程技巧
  • Android
  • swift
  • C#教程
  • vb
  • vb.net
  • C语言
  • Java
  • Delphi
  • 易语言
  • vc/mfc
  • 嵌入式开发
  • 游戏开发
  • ios
  • 编程问答
  • 汇编语言
  • 微信小程序
  • 数据结构
  • OpenGL
  • 架构设计
  • qt
  • 微信公众号

最近更新的内容

    • 解析BroadcastReceiver之你需要了解的一些东东,broadcastreceiver
    • Android Studio发布应用
    • PHP的readfile下载大文件时卡住
    • 滑动关闭activity,滑动activity
    • Android Butterknife 8.4.0 使用方法总结,butterknife8.4.0
    • Android开发笔记(5)——方法调用(基础),android笔记
    • Android自定义控件
    • Android.mk模板(持续更新中),android.mk更新中
    • Android实现按两次back键退出应用,android两次back键
    • Android-SQLite和SQLiteOpenHelper

关于我们 - 联系我们 - 免责声明 - 网站地图

©2020-2025 All Rights Reserved. linkedu.com 版权所有