使用AutoLayout遇到的坑。。

这个项目让我接触到了Android AutoLayout这个强大的适配框架,只需要根据设计稿的尺寸配置下面代码即可自动适配屏幕。。。
先来说说AutoLayout的用法,最后再说说遇到的坑

一、引入
在app文件夹的build.gradle添加如下代码:

dependencies {
    compile 'com.zhy:autolayout:1.4.3'
}

二、使用
在你的项目的AndroidManifest中注明你的设计稿的尺寸。

<meta-data android:name="design_width" android:value="768">
</meta-data>
<meta-data android:name="design_height" android:value="1280">
</meta-data>

然后写BaseActivity继承AutoLayoutActivity即可。

三、支持的属性
目前支持属性如下:
layout_width
layout_height
layout_margin(left,top,right,bottom)
pading(left,top,right,bottom)
textSize
maxWidth, minWidth, maxHeight, minHeight

四、默认使用的高度是设备的可用高度,也就是不包括状态栏和底部的操作栏的,如果你希望拿设备的物理高度进行百分比化:

可以在Application的onCreate方法中进行设置:

public class MyApplication extends Application
{
    @Override
    public void onCreate()
    {
        super.onCreate();
        AutoLayoutConifg.getInstance().useDeviceSize();
    }
}

五、遇到的坑
由于用到了CardView的控件,导致自适应失效,在查找原因后,终于找到了答案,原来CardView自适应是需要自己写扩展的。。。。。

我在网上找到资料,资料描述如下

对于其他继承系统的FrameLayout、LinearLayout、RelativeLayout的控件,比如CardView,如果希望再其内部直接支持"px"百分比化,可以自己扩展,扩展方式为下面的代码。

public class AutoCardView extends CardView
{
    private final AutoLayoutHelper mHelper = new AutoLayoutHelper(this);
    
    public AutoCardView(Context context)
    {
        super(context);
    }
    
    public AutoCardView(Context context, AttributeSet attrs)
    {
        super(context, attrs);
    }
    
    public AutoCardView(Context context, AttributeSet attrs, int defStyleAttr)
    {
        super(context, attrs, defStyleAttr);
    }
    
    @Override
    public AutoFrameLayout.LayoutParams generateLayoutParams(AttributeSet attrs)
    {
        return new AutoFrameLayout.LayoutParams(getContext(), attrs);
    }
    
    @Override
    protected void onMeasure(int widthMeasureSpec, int heightMeasureSpec)
    {
        if (!isInEditMode())
        {
            mHelper.adjustChildren();
        }
        super.onMeasure(widthMeasureSpec, heightMeasureSpec);
    }
    
}

本文参考了http://blog.csdn.net/fangfangthinker/article/details/52097701 这篇博客,感谢原作者的经验。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

友情链接更多精彩内容