zoukankan      html  css  js  c++  java
  • android:clipToPadding和android:clipChildren

    Android官网:

    android:clipChildren    setClipChildren(boolean)    Defines whether a child is limited to draw inside of its bounds or not.
    android:clipToPadding    setClipToPadding(boolean)    Defines whether the ViewGroup will clip its children to its padding, if padding is not zero.

    一、假设我们要做一个效果,界面最顶部是一个ActionBar并且是半透明的,ActionBar下面是一个ListView,在初始状态下,ListView是top是在ActionBar的bottom位置的,但当ListView滚动的时候可以透过ActionBar看到下面的ListView的内容。如下面两张图所示:

    正常态:

    normal

    滚动态:

    scroll

    乍一看,不是很简单吗,只要设置一下marginTop或者paddingTop就可以了,但问题是只用这两个其中一个属性的话,ListView滑动的时候就不能滚到paddingTop或者marginTop那部分区域,有人说可以用HeaderView来解决,这是其中一个办法,但仅仅了为这个占空使用HeadView有点浪费而且会影响onItemClick的position.于是这里介绍可以到这个效果的两个属性,就是android:clipToPadding和android:clipChildren,这两个属性不是太多人用到,这里说明一下

    clipToPadding就是说控件的绘制区域是否在padding里面的,true的情况下如果你设置了padding那么绘制的区域就往里缩,clipChildren是指子控件是否超过padding区域,这两个属性默认是true的,所以在设置了padding情况下,默认滚动是在padding内部的,要达到上面的效果主要把这两个属性设置了false那么这样子控件就能画到padding的区域了。

    Java
    1
    2
    3
    4
    5
    6
    7
    8
    <ListView
        android:layout_gravity="center_vertical"
        android:id="@+id/list"
        android:clipChildren="false"
        android:clipToPadding="false"
        android:paddingTop="50dip"
        android:layout_width="match_parent"
        android:layout_height="match_parent">

    Actionbar半透明就不详细说了,只要设置actionbarOverlay为true并为ActionBar设置一个半透明的background即可.

    二、ClipChildren

    1、只需在根节点设置

    2、可以通过android:layout_gravity控制超出的部分如何显示。

    原文:http://www.alloyteam.com/2014/10/androidcliptopadding-he-androidclipchildren/?utm_source=tuicool

  • 相关阅读:
    angular打包出现JavaScript堆内存不足
    antDesign 【NG-ZORRO、Angular】日期选择框时间段nz-range-picker设置默认选择日期及限制日期可选范围
    Echarts 折线图Demo调色12种,可以直接使用~~~
    公司版git完整版
    Linux实例重启服务器后root用户远程连接失败
    Flask+Redis+mq实现高并发
    Dockerfile
    Docker应用部署
    RabbitMQ 实现实现基本通信及订单处理
    centos 7 安装docker的文档参考
  • 原文地址:https://www.cnblogs.com/veins/p/4372325.html
Copyright © 2011-2022 走看看