位置: 编程技术 - 正文

Android Support库百分比布局(android design库)

编辑:rootadmin

推荐整理分享Android Support库百分比布局(android design库),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:androidhelper库,androidui库,apk库,android 下载库,安卓support库,androidui库,androidx库,安卓support库,内容如对您有帮助,希望把文章链接给更多的朋友!

之前写过一篇屏幕适配的文章Android 屏幕适配最佳实践,里面提到了类似百分比布局的东西,但是该方法缺点很明显,就会增加很多无用的数据,导致apk包变大。

而谷歌的support库中,增加了一个叫做percent库,该库在如图目录下,如果没有,请使用sdk manager更新至最新

在使用前,我们先看下这个库有哪些类

很明显里面有一个FrameLayout布局的子类和RelativeLayout布局的子类,此外还有一个Helper类,这个Helper类主要是完成百分比的测量工作,里面有一个接口PercentLayoutParams,如果我们自己要实现百分比布局,那么就要实现这个接口。

我们看下谷歌对外公布了什么自定义属性

看到这些属性应该能直接明白这些属性的意思,其属性值类型为fraction,即小数,百分比。主要属性有宽度,高度占是百分比,外边距的百分比,其中Android MarginLeft与MarginStart的区别参考Android MarginLeft与MarginStart的区别,提取关键内容如下。

在写layout布局的时候,我们会发现有这样几个比较相似的属性: MarginStart MarginLeft MarginEnd MarginRight

这些属性的区别是什么? 根据api注释,我们得知MarginStart指的是控件距离开头View部分的间距大小,MarginLeft则指的是控件距离左边View部分的间距大小,MarginEnd和MarginRight同理。

一般情况下,View开始部分就是左边,但是有的语言目前为止还是按照从右往左的顺序来书写的,例如阿拉伯语,在Android 4.2系统之后,Google在Android中引入了RTL布局,更好了支持了由右到左文字布局的显示,为了更好的兼容RTL布局,google推荐使用MarginStart和MarginEnd来替代MarginLeft和MarginRight,这样应用可以在正常的屏幕和由右到左显示文字的屏幕上都保持一致的用户体验。

了解了这些后,我们开始使用PercentRelativeLayout

使用前加入库文件依赖

Android Support库百分比布局(android design库)

开始编写布局文件,我们要实现的效果如图所示

即左边红色部分宽度占屏幕%,高度占屏幕%,右边宽度占屏幕%,高度各占屏幕%。在不使用百分比布局之前,我们一般是使用LinearLayout的weight达到这种效果,然而使用weight会增加布局的嵌套,会过度绘制。那么使用百分比布局会变成什么样的,无需布局嵌套,设置高度宽度百分比即可。

我们要设置左边的布局宽度占%,使用app:layout_widthPercent=”%”,高度占%,为了演示另一个属性的使用,这里不直接设置高度为%,而是设置高度为%,底边距为%,即

同理编写右边两个的布局。

正如文章开头看到的,这个库只提供了两个百分比布局给我们使用,比较常见的线性布局并没有提供对应的百分比布局。因此,我们想能不能自己实现一个呢,答案是肯定的,通过观察现有的两个百分比布局的代码,我们需呀继承原来的布局,即LinearLayout,编写对应的构造方法调用父类。声明一个PercentLayoutHelper对象辅助完成百分比测量,此外还需要重写onMeasure和onLayout方法,以及一个 实现了PercentLayoutHelper.PercentLayoutParams接口的继承原来布局的LayoutParams的LayoutParams。

那么我们新建一个叫PercentLinearLayout的继承LinearLayout的类,实现其构造方法,以及声明一个final的PercentLayoutHelper 对象。

仿造现有的两个百分比布局实现内部类LayoutParams ,这一步直接复制代码修改一下即可,记得一定要继承自android.widget.LinearLayout.LayoutParams。

此外,还要重写一个生成LayoutParams 的方法generateLayoutParams,返回我们的内部类。

然后重新onLayout和onMeasure方法即可,这一步也不需要自己实现,直接复制代码即可。

就这样,完成了百分比线性布局,我们进行使用下。完成下面的效果,随意发挥的涂鸦。

主要是红色部分,从上到下,高度各为父容器的%,%,%,宽度各为父容器的%,%,,其中第三个靠右边布局,右边距为父容器的%,同时有上边距为父容器的%,看代码更直接

怎么样,是不是轻轻松松就实现了百分比布局,更多内容自行挖掘,下面上源码

版权声明:本文为博主原创文章,未经博主允许不得转载。

Github上优秀的Android开源项目常用控件 一、ListView1.android-pulltorefresh一个强大的拉动刷新开源项目,支持各种控件下拉刷新ListView、ViewPager、WevView、ExpandableListView、GridView、(Horizontal)ScrollView、F

从 Android 本地图库选择多个图片

android开发过程中自定义动画加载进度条实现过程 开发过程中需要自定义开发一个加载进度条显示,这里记录下来方便以后查找。首先:定义一个anim文件夹下的animation.xml配置文件:?xmlversion=1.0encoding=utf

标签: android design库

本文链接地址:https://www.jiuchutong.com/biancheng/378056.html 转载请保留说明!

上一篇:iTOP4412开发板去掉底板上的重力加速(开发板io口在哪)

下一篇:Github上优秀的Android开源项目常用控件(github上有什么)

  • 诚信纳税的含义是什么
  • 工资个税计算公式2020
  • 已开普通发票记账联丢失怎么办?
  • 非正常损失的进项税额转出公式
  • 红冲以前年度收入成本的账务处理
  • 税务异常有哪些类型
  • 一般纳税人有免征增值税吗
  • 月末 存款
  • 为什么纳税申报
  • 处置子公司全部股权会计处理 企业会计准则
  • 认缴出资股权转让的法律责任
  • 财产租赁个人所得税
  • 私对公转错了多久退回来
  • 银行抵债资产处置需要缴纳什么税费
  • 购置办公大楼
  • 验资帐户
  • 生产企业出口退税流程及账务处理
  • 增值税开错了
  • 软件著作权认证查询
  • 华为nova9参数配置中关村
  • 华为鸿蒙一键抠图
  • 如何测试电脑网速多少兆
  • 股东能随便提走入账资金吗
  • macbookpro任务栏
  • 误餐费怎么入账
  • 2014年最佳阵容
  • win10开始菜单设置无效
  • PHP:stream_get_filters()的用法_Stream函数
  • PHP:pg_parameter_status()的用法_PostgreSQL函数
  • dae是什么文件
  • php $_files
  • 代缴费社保
  • 收回已核销的坏账分录
  • 魅族路由器怎么样
  • 固定资产抵债账务怎么处理
  • 实际交印花税会计分录
  • php操作mysql数据库
  • yolo object detection
  • php运算符@符号
  • userpasswords
  • 多计提费用可以不用以前年度损益调整吗
  • phpweb缓存技术
  • 水利建设专项收入的税率是多少?
  • 跨境电商企业账务如何做账
  • 一般纳税人进项大于销项账务处理
  • pycharm折叠代码块快捷键
  • 过路费一定是要公司的车辆吗
  • 原材料盘盈会计处理
  • 减值准备的会计科目
  • 申报成功后怎么更正申报
  • 教育费附加退费
  • 年底存货反映了什么
  • 小规模个人所得税税率表2023年
  • 期末贷方余额什么意思
  • 资产负债表本期没有发生额怎么填
  • sql查询速度慢如何优化
  • 快速插入大量数据的asp.net代码(Sqlserver)
  • mysql 绿色版安装
  • svchost一直在下载什么
  • windows10推送
  • Ubuntu安装VMware tools
  • redis-stat监控
  • centos7添加ip地址
  • xp如何禁用445
  • win7怎么设置快
  • win10推送升级win11
  • react all in js
  • 跨浏览器跨终端的前端开发
  • 编写批处理
  • 深入理解计算机系统
  • nodejs 路由
  • unity常用api
  • python3 random模块
  • 爱加密企业版
  • javascript闭包的作用
  • android 数据
  • jquery 插件写法
  • 税务系统 网络发票
  • 发票上的税务号
  • 公司小规模怎么纳税
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设